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 呢,按我表里查询应该是有记录的?求指教 展开
 我来答
xu3180497
推荐于2018-05-10 · TA获得超过1659个赞
知道小有建树答主
回答量:390
采纳率:66%
帮助的人:197万
展开全部

我知道你的@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)了。另外说一句,下次记得贴代码,你贴个图,我打字还得打半天。

gwurn514
2014-05-22 · TA获得超过157个赞
知道答主
回答量:95
采纳率:0%
帮助的人:134万
展开全部
整个语句块创建了一个存储过程,其中的查询使用了存储过程的参数。你可以通过直接执行存储过程,将值传给传出过程的参数,来实现执行查询。
例如:
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 )
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式