SQL 存储过程变量
set@bb1=(selectcount(*)FROMCxuqiuwhere@b='1'and@b1='1')为什么@bb1中的数据是0呢,按我表里查询应该是有记录的?求...
set @bb1=(select count(*) FROM Cxuqiu where @b='1' and @b1='1')为什么@bb1中的数据是0 呢,按我表里查询应该是有记录的?求指教
展开
2个回答
展开全部
我知道你的@b和@b1是这个表的变量,你可以尝试输出@b和@b1看看是什么
set @bb1=(select count(*) FROM Cxuqiu where @b='1' and @b1='1')
select @b,@b1
或者输出整个语句看看是否有问题:
declare @bb1 int
declare @b varchar(12)
declare @b1 varchar(30)
declare @sql varchar(1000)
set @b = 'id'
set @b1 = 'str0'
set @bb1=(select count(*) FROM Cxuqiu where @b='1' and @b1='1')
select @sql = '(select count(*) FROM Cxuqiu where '+ @b +' = ''1'' and '+ @b1 +' = ''1'')'
print @sql
select @bb1
--上面的set 是我随便写的,你把你的列值代入进去即可。
主要是print @sql这句,打印输出你的动态SQL语句,然后执行这个打印出来的结果才能发现问题。
更多追问追答
追答
declare @count int ---放在声明部分
begin
select @sql = 'select @tmp = count(*) from Cxuqiu where '+@a+'=1 and '+@b+'=1 '
exec sp_executesql @sql,N'@tmp int output', @tmp = @count output
print @j
end
可以去掉上面的exec(@sql)了。另外说一句,下次记得贴代码,你贴个图,我打字还得打半天。
展开全部
整个语句块创建了一个存储过程,其中的查询使用了存储过程的参数。你可以通过直接执行存储过程,将值传给传出过程的参数,来实现执行查询。
例如:
execute dbo].[p_sele_sp] '%a%','1%',‘aaa%’,'bbb%';
如果希望直接执行查询语句,则需要用declare关键字事先声明变量。如下:
-- 声明变量
declare @spbh varchar(20) , @zjm varchar(100) , @sptm varchar(20) , @splb varchar(20)
-- 给变量赋值
set @spbh = ’%a%'
set @zjm = '1%'
set @sptm = ‘aaa%’
set @splb = 'bbb%'
--执行查询
SELECT TOP 200 spbh,spname,dw,spgg,scqy,spcd,sl,lsj,zdsj,spid,splb,jj,
sptm,spsx,kfid,jx,pzwh,is_sy,jbz,zbz,ajia,bjia,cjia,djia,bz,bz1,bz2,bz3,bz4,bz5,bz6,bz7,bz8,bz9
FROM t_sp_info
WHERE ( status = '是' ) AND
( pym like @zjm OR spname like @zjm OR spbh like @spbh OR sptm like @sptm ) AND ( splb like @splb )
例如:
execute dbo].[p_sele_sp] '%a%','1%',‘aaa%’,'bbb%';
如果希望直接执行查询语句,则需要用declare关键字事先声明变量。如下:
-- 声明变量
declare @spbh varchar(20) , @zjm varchar(100) , @sptm varchar(20) , @splb varchar(20)
-- 给变量赋值
set @spbh = ’%a%'
set @zjm = '1%'
set @sptm = ‘aaa%’
set @splb = 'bbb%'
--执行查询
SELECT TOP 200 spbh,spname,dw,spgg,scqy,spcd,sl,lsj,zdsj,spid,splb,jj,
sptm,spsx,kfid,jx,pzwh,is_sy,jbz,zbz,ajia,bjia,cjia,djia,bz,bz1,bz2,bz3,bz4,bz5,bz6,bz7,bz8,bz9
FROM t_sp_info
WHERE ( status = '是' ) AND
( pym like @zjm OR spname like @zjm OR spbh like @spbh OR sptm like @sptm ) AND ( splb like @splb )
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询