declare @topp int
declare @str nvarchar(256)
set @topp=2 
select @str='select top '+@topp+' n_id from tab1'
exec @str

解决方案 »

  1.   

    exec('select top '+@topp+' n_id from tab1')
      

  2.   

    --top不支持变量declare @topp int
    set @topp=2 
    set rowcount @topp
    select  n_id from tab1
      

  3.   

    --top不支持变量declare @topp int
    set @topp=2 
    set rowcount @topp
    select  n_id from tab1
      

  4.   

    用动态语句:
    1:
    普通SQL语句可以用Exec执行
    eg:   Select * from tableName
          Exec('select * from tableName')
          sp_executesql N'select * from tableName'    -- 请注意字符串前一定要加N2:
    字段名,表名,数据库名之类作为变量时,必须用动态SQL
    eg:   
    declare @fname varchar(20) 
    set @fname = '[name]'
    Select @fname from sysobjects                     -- 错误
    Exec('select ' + @fname + ' from sysobjects')     -- 请注意 加号前后的 单引号的边上要加空格
    exec sp_executesql N' select ' + @fname + ' from sysobjects' 
    当然将字符串改成变量的形式也可
        declare @s varchar(1000)
        set @s = 'select ' + @fname + ' from sysobjects'
        Exec(@s)                -- 成功
        exec sp_executesql @s   -- 此句会报错    declare @s Nvarchar(1000)  -- 注意此处改为nvarchar(1000)
        set @s = 'select ' + @fname + ' from sysobjects'
        Exec(@s)                -- 成功    
        exec sp_executesql @s   -- 此句正确,
      

  5.   

    declare @topp varchar(20)  --注意定义为字符变量
    declare @sql varchar(1000)
    set @topp='2' set @sql='select top ' + @topp + ' n_id from tab1'
    exec (@sql)  ---执行动态sql语句