关于SQL server动态SQL的连接语法

关于SQL server动态SQL的连接语法

1. 从拼接后的SQL结果角度会更容易理解如下规则

字符型字段条件值拼接后需要保留一个单引号’,需要在拼接SQL时明确指定双单引号才可以达成一个单引号的结果, 典型语法:' and  ''' + @X + '''';
而数值型条件值拼接不需要保留单引号,update后的表名连接也不需要保留单引号。

语法实例:
execute ('update '+ @TempTableName +' set iCost=iQtty * b.iIACost from ' +@TempTableName +' inner join '+ ......

set @execSql = 'SELECT a.sCardNum, .....FROM fa_Cards a with(nolock) INNER JOIN #YXKP ON a.sCardID = #YXKP.sCardID 
                inner join fa_deptscale c with(nolock) on a.loptid = c.loptid and a.sCardNum = c.sCardNum
                INNER JOIN fa_DeprTransactions_detail b with(nolock) ON a.sCardNum = b.sCardNum and c.sDeptNum = b.sDeptNum  where b.iyear = ' + @iQueryYear + ' and isnuLL(bMultiDept,0) >= ' + @bOnlyMulti

IF @sDeptNum <> '' 
    set @execSql =  @execSql + ' and b.sDeptNum = ''' + @sDeptNum + ''''

2. 所有数值型参数要改成字符型

3.执行动态SQL一定要用括号():exec (@cSQL)

4. 字符数据类型建议都用【nvarchar】,因为只有sp_executesql支持输出参数且仅支持unicode数据类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值