存储过程拼接字符串

ALTERPROCEDUREdbo.Staff_Select@StaffNamenvarchar(30)=NULL,@Sexnvarchar(10)=NULLAS/*SE... ALTER PROCEDURE dbo.Staff_Select
@StaffName nvarchar(30)=NULL,
@Sex nvarchar(10)=NULL
AS
/* SET NOCOUNT ON */
DECLARE @CONDITION nvarchar(1000)
SET @CONDITION = 'SELECT * FROM Staff WHERE 1=1'

IF @StaffName IS NOT NULL
SET @CONDITION = @CONDITION + ' AND StaffName='+''''+@StaffName+''''
IF @Sex IS NOT NULL
SET @CONDITION = @CONDITION + ' AND Sex='+''''+@Sex+''''

EXEC(@CONDITION)

RETURN
按照网上的说法,拼接时只需要三个’,但我的却要报错,用四个‘(上面正确)就是正常的!求解.........
展开
 我来答
szm341
推荐于2017-11-26 · TA获得超过6726个赞
知道大有可为答主
回答量:5005
采纳率:100%
帮助的人:5156万
展开全部
字符串的拼接,两个单引号之间的叫字符串,字符串内部的单引号要用两个代表一个
拼接时,可以先把两边的单引号写好,然后再写字符串内部的单引号
如'abc'如果要给b两边加单引号就再'a''b''c',像这样在b两边加上两个单引号
HaiziCattle
2013-11-12 · TA获得超过125个赞
知道小有建树答主
回答量:298
采纳率:0%
帮助的人:192万
展开全部
网上说的三个是在字符串的开始 或结束位置 如 select @sqlstr = 'select '+'''col1'',col2 from tab1'
这个sqlstr 结果 为 select ’col1‘,col2 from tab1
追问
为什么要三个字符呢?有什么意义
追答
如果表示字符串中的单引号,需要进行转义,其中转义符就是单引号,你查查官方文档吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式