现在的位置: 首页 > 综合 > 正文

学习SQL应知道的动态SQL语句基本语法(阅读)

2012年10月26日 ⁄ 综合 ⁄ 共 1240字 ⁄ 字号 评论关闭
  1. 1 、普通SQL语句可以用Exec执行 
  2. eg: Select * from tableName  
  3. Exec('select * from tableName')  
  4. Exec sp_executesql N'select * from tableName' -- 请注意字符串前一定要加N 
  5. -- 一定要大写的N 
  6. 2、字段名,表名,数据库名之类作为变量时,必须用动态SQL 
  7. eg:  
  8. declare @fname varchar(20)  
  9. set @fname = 'FiledName'  
  10. Select @fname from tableName -- 错误,不会提示错误,但结果为固定值FiledName,并非所要。  
  11. Exec('select ' + @fname + ' from tableName') -- 请注意 加号前后的 单引号的边上加空格  
  12. 大气象添加:top后面跟参数时,需要这样用。
  13. declare @CustomerID int
  14. set @CustomerID = 10
  15. exec('select top ' + @CustomerID + '* from Orders')
  16. 当然将字符串改成变量的形式也可  
  17. declare @fname varchar(20)  
  18. set @fname = 'FiledName' --设置字段名  
  19. declare @s varchar(1000)  
  20. set @s = 'select ' + @fname + ' from tableName'  
  21. Exec(@s) -- 成功  
  22. exec sp_executesql @s -- 此句会报错  
  23. 大气象添加:简化一下
  24. declare 
  25. @s varchar(20)
  26. set 
  27. @s='select * from Orders'
  28. exec(@s)
  29. declare @s Nvarchar(1000) -- 注意此处改为nvarchar(1000)  
  30. set @s = 'select ' + @fname + ' from tableName'  
  31. Exec(@s) -- 成功  
  32. exec sp_executesql @s -- 此句正确  
  33. 3、输出参数 
  34. declare @num int,  
  35. @sqls nvarchar(4000)  
  36. set @sqls='select count(*) from tableName'  
  37. exec(@sqls)  
  38. --如何将exec执行结果放入变量中?  
  39. declare @num int,  
  40. @sqls nvarchar(4000)  
  41. set @sqls='select @a=count(*) from tableName '  
  42. exec sp_executesql @sqls,N'@a int output',@num output  
  43. select @num  
  44. 此外,如果想要在SQL语句 字符串中使用 单引号 '' 可以 使用 ''''

081113

抱歉!评论已关闭.