请帮我详解一下这条语句,谢谢
exec sp_executesql @sql, N'@count int out,@id varchar(20)', @cou out ,@id
@sql为拼成的动态sql
N'@count int out,@id varchar(20)'为拼成的动态sql内的参数列表
@cou out,@id为为动态sql内参数列表提供值的外部参数列表
就这条语句,有些有带说明了,想知道,N'这个代表什么意思,@count int out这是不是表示整型输出参数@count。。@cou out 和@count int out的实质区别是什么
------解决方案--------------------N标示字符串为Unicode 类型
@cou out 和@count int out
@cou是接收的参数,接收动态SQL的输出参数@count的值
@count是定义一个变量,并标示这个变量时输出参数的
------解决方案--------------------@id 是接收传来的值
------解决方案--------------------纸上谈兵有何用,问出来的结果可不可靠,还要自己验证。
declare @id int, @cn int
select top 1 @id = id from syscolumns
exec sp_executesql
N'select @cn=count(1) from syscolumns where id=@id',
N'@cn int out,@id int', @cn out, @id
select @cn, count(1) from syscolumns where id=@id