Sql=”select count(*) from table”;
Sql=”selectcount(*)fromtable”;当这个table为变量的时候,这个Sql语句怎么写?...
Sql=”select count(*) from table”;
当这个table为变量的时候,这个Sql语句怎么写? 展开
当这个table为变量的时候,这个Sql语句怎么写? 展开
4个回答
展开全部
字段名,表名,数据库名之类作为变量时,必须用动态SQL
eg:
declare @fname varchar(20)
set @fname = 'FiledName'
Select @fname from tableName -- 错误,不会提示错误,但结果为固定值FiledName,并非所要。
Exec('select ' + @fname + ' from tableName') -- 请注意 加号前后的 单引号的边上加空格
当然将字符串改成变量的形式也可
declare @fname varchar(20)
set @fname = 'FiledName' --设置字段名
declare @s varchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句会报错
declare @s Nvarchar(1000) -- 注意此处改为nvarchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句正确
就写这么多了!希望对你有所帮助
eg:
declare @fname varchar(20)
set @fname = 'FiledName'
Select @fname from tableName -- 错误,不会提示错误,但结果为固定值FiledName,并非所要。
Exec('select ' + @fname + ' from tableName') -- 请注意 加号前后的 单引号的边上加空格
当然将字符串改成变量的形式也可
declare @fname varchar(20)
set @fname = 'FiledName' --设置字段名
declare @s varchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句会报错
declare @s Nvarchar(1000) -- 注意此处改为nvarchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句正确
就写这么多了!希望对你有所帮助
展开全部
table 应该是数据库中表的名字啊!!
table作为变量的时候也就是需要查询不同表中的信息
select count(*) from table 意思是查询table表中的一个信息
//count(*)返回第一行第一列的值
table作为变量的时候也就是需要查询不同表中的信息
select count(*) from table 意思是查询table表中的一个信息
//count(*)返回第一行第一列的值
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
tablename="XXXX";
Sql="select count(*) from "+tablename;
Sql="select count(*) from "+tablename;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
declare @sql varchar(200)
declare @table varchar(50)
@sql='select count(*) from '+@table
exec (@sql)
declare @table varchar(50)
@sql='select count(*) from '+@table
exec (@sql)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询