zoukankan      html  css  js  c++  java
  • 存储过程中的top+变量(downmoon)

    存储过程中的TOP后跟一个变量会如何?
    Create proc getWorkPlan2
    (
    @intCounter int
    ,
    @lngUserID int)

    as
    select Top 5 lngWorkID,strWorkName,strExecHumanName,strBeginDate
    from worklist where lngExecHumanID= @lngUserID
    order by lngWorkID desc 
    现在想将这里的Top 5 改为变量· Top @intCounter
    如下

    ALTER proc getWorkPlan2
    (
    @intCounter int
    ,
    @lngUserID int)
    as  
    )
    exec sp_executesql ('select Top '+convert(varchar(10),@intCounter)+' lngWorkID,strWorkName,strExecHumanName,strBeginDate from worklist where lngExecHumanID= '
    +convert(varchar(10),@lngUserID+' order by lngWorkID desc '

    老是提示 在关键字 'convert' 附近有语法错误。
    OK!

    于是改为


    ALTER proc getWorkPlan2
    (
    @intCounter int
    ,
    @lngUserID int)

    as
    declare @strCounter varchar(10)
    set @strCounter=convert(varchar(10),@intCounter)
    declare @strUserID varchar(10)
    set @strUserID=convert(varchar(10),@lngUserID)
    exec sp_executesql ('select Top '+@strCounter+' lngWorkID,strWorkName,strExecHumanName,strBeginDate from worklist where lngExecHumanID= '
    +@strUserID +' order by lngWorkID desc '
    )

     后来,经saucer(思归)大哥提醒,发现可以用以下语句实现(sql2005/2008): 

    Alter proc getWorkPlan2
    (
    @intCounter int
    ,
    @lngUserID int
    )
    as
    set rowcount @intCounter
    select  lngWorkID,strWorkName,strExecHumanName,strBeginDate
    from worklist where lngExecHumanID= @lngUserID
    order by lngWorkID desc 
  • 相关阅读:
    Python使用print打印时,展示内容不换行
    二进制、八进制、十进制和十六进制的相互转化(图解)
    IDEA 配置背景颜色(豆沙绿)
    Linux下脚本文件第一行的作用
    IDEA 注释模板配置
    IDE 常用配置
    Python 运算符
    Python 基础
    Chrome 浏览器快捷键
    正则表达式
  • 原文地址:https://www.cnblogs.com/flysun0311/p/2065713.html
Copyright © 2011-2022 走看看