MSSQL2005 INSERT,UPDATE,DELETE 之OUTPUT子句使用实例

睡不睡还是要睡

睡不睡还是要睡

2016-02-19 10:48

今天图老师小编给大家精心推荐个MSSQL2005 INSERT,UPDATE,DELETE 之OUTPUT子句使用实例教程,一起来看看过程究竟如何进行吧!喜欢还请点个赞哦~
代码如下:

--Title:Generating test data
--Author:wufeng4552
--Date :2009-10-07 15:16:26
if object_id('ta')is not null drop table ta
go
create table ta(ID int identity,[name] varchar(10))
insert ta([name]) select 'a' union all
select 'b' union all
select 'c' union all
select 'd' union all
select 'e' union all
select 'f' union all
select 'g'
if object_id('tb')is not null drop table tb
go
create table tb(ID int identity,[name] varchar(10))
insert tb([name]) select 'a' union all
select 'b' union all
select 'c'
--INSERT 陳述式來使用 OUTPUT INTO
insert tb output
inserted.id,
inserted.[name]
select [name]
from ta where not exists(select 1 from tb where [name]=ta.[name])
/*
id name
----------- ----------
4 d
5 e
6 f
7 g
*/
--刪除剛才插入的紀錄
delete tb where [name]'c'
--储存此结果集保存到一个表值变量中
declare @t table(ID int,[name] varchar(10))
insert tb output
inserted.id,
inserted.[name]into @t
select [name] from ta where not exists(select 1 from tb where [name]=ta.[name])
select * from @t
/*
ID name
----------- ----------
8 d
9 e
10 f
11 g
(4 個資料列受到影響)
*/
--DELETE 陳述式使用 OUTPUT
delete tb output deleted.* where id=9
/*
ID name
----------- ----------
9 e
(1 個資料列受到影響)
*/
-- UPDATE 陳述式使用 OUTPUT INTO
update tb set [name]='test' output inserted.* where id=10
/*
ID name
----------- ----------
10 test
(1 個資料列受到影響)
*/
/*
OUTPUT 子句对于在 INSERT操作之后检索标识列或计算列的值可能非常有用。
另外OUTPUT子句也可以在UPDATE和DELETE语句中使用,从插入表或删除表中得到数值,并返回这些数值。
以下语句中不支持 OUTPUT 子句:
l 引用本地分区视图、分布式分区视图或远程表的 DML 语句。
l 包含 EXECUTE 语句的 INSERT 语句。
l 不能将 OUTPUT INTO 子句插入视图或行集函数。
简洁的OUTPUT子句,使得向SQL Server导入数据的操作得到了极大的简化。
展开更多 50%)
分享

猜你喜欢

MSSQL2005 INSERT,UPDATE,DELETE 之OUTPUT子句使用实例

编程语言 网络编程
MSSQL2005 INSERT,UPDATE,DELETE 之OUTPUT子句使用实例

MSSQL output使用

编程语言 网络编程
MSSQL output使用

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

mssql2005注入方法小结

编程语言 网络编程
mssql2005注入方法小结

开启MSSQL2005的远程登录

编程语言 网络编程
开启MSSQL2005的远程登录

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

MSSQL2005数据库备份导入MSSQL2000

编程语言 网络编程
MSSQL2005数据库备份导入MSSQL2000

SQL Server中的XML数据进行insert、update、delete

编程语言 网络编程
SQL Server中的XML数据进行insert、update、delete

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

Win10如何删除Media Player播放器

Win10如何删除Media Player播放器

Android点亮屏幕或屏幕解锁和锁定以及其他相关权限实现代码

Android点亮屏幕或屏幕解锁和锁定以及其他相关权限实现代码
下拉加载更多内容 ↓