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的实质区别是什么

解决方案 »

  1.   

    N标示字符串为Unicode 类型@cou out 和@count int out
    @cou是接收的参数,接收动态SQL的输出参数@count的值
    @count是定义一个变量,并标示这个变量时输出参数的
      

  2.   

    N'..'指示后面的是nvarchar(unicode)字符串
    @count int out (内部参数列表)整数输出
    @cou out (外部参数列表)接收@count的输出
    内外参数列表一一对应,out表示传出参数,无out表示传入参数
      

  3.   


    那这个 @cou out 和@id 又有什么不同,id是否也是接收@id传来的值,他是否也可以输出
      

  4.   

    纸上谈兵有何用,问出来的结果可不可靠,还要自己验证。declare @id int, @cn int
    select top 1 @id = id from syscolumnsexec sp_executesql
    N'select @cn=count(1) from syscolumns where id=@id',
    N'@cn int out,@id int', @cn out, @idselect @cn, count(1) from syscolumns where id=@id