動態sql語句基本語法

本文介绍了动态SQL的基本语法,包括如何使用EXEC和sp_executesql执行动态SQL语句,以及如何设置变量来动态地构建SQL查询。同时,文章还探讨了如何通过动态SQL处理表名、字段名等作为变量的情况,并提供了输出参数的实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 動態sql語句基本語法
1 :普通SQL語句可以用Exec執行

eg: Select * from tableName
Exec('select * from tableName')
Exec sp_executesql N'select * from tableName' -- 請注意字串前一定要加N

2:欄位名,表名,資料庫名之類作為變數時,必須用動態SQL

eg:
declare @fname varchar(20)
set @fname = 'FiledName'
Select @fname from tableName -- 錯誤,不會提示錯誤,但結果為固定值FiledName,並非所要。
Exec('select ' + @fname + ' from tableName') -- 請注意 加號前後的 單引號的邊上加空格

當然將字串改成變數的形式也可
declare @fname varchar(20)
set @fname = 'FiledName' --設置欄位名

declare @s varchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句會報錯

 

declare @s Nvarchar(1000) -- 注意此處改為nvarchar(1000)
set @s = 'select ' + @fname + ' from tableName'
Exec(@s) -- 成功
exec sp_executesql @s -- 此句正確

3. 輸出參數
declare @num int, @sql nvarchar(4000)
set @sql='select count(*) from tableName'
exec(@sql)


--如何將exec執行結果放入變數中?

declare @num int, @sql nvarchar(4000)
set @sql='select @a=count(*) from tableName '
exec sp_executesql @sql,N'@a int output',@num output
select @num

----修改表的主鍵
ALTER TABLE EXAMCOURSE
ADD
CONSTRAINT PK_BH
PRIMARY KEY (id,alias)

exec  sp_helpconstraint  'examcourse'  

alter   table   examcourse   drop   constraint  pk_EXAMCOURSE_1

----設置多欄位連接顯示
declare @ss varchar(100) set @ss=''select @ss=@ss+ rtrim(a.alias) +';' from examcourse a select substring(@ss,0,len(@ss)-1) ss

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值