SqlServer语句拼接时添加单引号

问题来源:今天在编写存储过程的时候,遇到了筛选条件时间段 beginTime  EndTime ,  直接使用这个变量拼接sql语句是不能识别的 ,必须添加单引号

现在写出来以备后用,(提醒自己别忘了这么简单的事)

declare @beginTime   nvarchar(50)
declare @EndTime   nvarchar(50)
declare @Sql   nvarchar(100)
set @Sql='select * from  Flow_TenderReviewApproval A where A.Times bewteen '''+@beginTime+''' and '''+@EndTime+''''
exec(@Sql)

顺便在记录一下: exec()  可以执行Sql或存储过程

 

 

******************************** 分界线*********************************

后来,我发现了一种更为简单的方式去避免字符串拼接,记录一下

无意中在网上看到还有这样的写法 所以对于单引号字符串拼接不熟悉的可以使用这种方式,效果是完全相同的,这样看起来更加通俗易懂,避免了字符串中的单引号拼接

declare @beginTime   nvarchar(50)
declare @EndTime   nvarchar(50)
declare @Sql   nvarchar(100)
select * from  Flow_TenderReviewApproval A where A.Times bewteen (select @beginTime) and (select @EndTime)

 

posted @ 2021-05-28 09:38  就爱啃西瓜  阅读(2680)  评论(0编辑  收藏  举报