原文地址:http://blog.sina.com.cn/s/blog_71460d950100nld2.html

OUTPUT是SQL SERVER2005的新特性.可以从数据修改语句中返回输出.可以看作是"返回结果的DML".INSERT,DELETE,UPDATE均支持OUTPUT子句.在OUTPUT子句中,可以引用特殊表inserted和deleted.使用inserted和deleted表与在触发器中使用的非常相似.

在INSERT,DELETE,UPDATE中OUTPUT的区别

1.对于INSERT,可以引用inserted表以查询新行的属性.

2.对于DELETE,可以引用deleted表以查询旧行的属性.

3.对于UPDATE,使用deleted表查询被更新行在更改前的属性,用inserted表标识被更新行在更改后的值.

输出方式:

1.可以输出给调用方(客户端应用程序)

2.输出给表

3.两者皆可.

应用:

一.带有OUTPUT的INSERT的应用

对于包含自增列的表执行多行insert语句,同时想知道新的标识值时,在INSERT中使用OUTPUT子句非常方便.对于单行INSERT语句,这不成问题:SCOPE_IDENTITY函数即可实现.

  1. -- Generating Surrogate Keys for Customers
  2. USE tempdb;
  3. GO
  4. IF OBJECT_ID('dbo.CustomersDim') IS NOT NULL
  5. DROP TABLE dbo.CustomersDim;
  6. GO
  7. CREATE TABLE dbo.CustomersDim
  8. (
  9. KeyCol      INT          NOT NULL IDENTITY PRIMARY KEY,
  10. CustomerID  NCHAR(5)     NOT NULL,
  11. CompanyName NVARCHAR(40) NOT NULL,
  12. );
  13. -- Insert New Customers and Get their Surrogate Keys
  14. DECLARE @NewCusts TABLE
  15. (
  16. CustomerID NCHAR(5) NOT NULL PRIMARY KEY,
  17. KeyCol     INT      NOT NULL UNIQUE
  18. );
  19. INSERT INTO dbo.CustomersDim(CustomerID, CompanyName)
  20. OUTPUT inserted.CustomerID, inserted.KeyCol
  21. INTO @NewCusts
  22. -- OUTPUT inserted.CustomerID, inserted.KeyCol
  23. SELECT CustomerID, CompanyName
  24. FROM Northwind.dbo.Customers
  25. WHERE Country = N'UK';
  26. SELECT CustomerID, KeyCol FROM @NewCusts;
  27. GO

注意代码中被注释掉的第二个OUTPUT子句,后面没有INTO子句.如果还要输出返回给调用方,取消注释即可.这样,INSERT语句将包含两个OUTPUT子句.

示例2.

  1. USE AdventureWorks;
  2. GO
  3. CREATE TABLE TestTable (ID INT, TEXTVal VARCHAR(100))
  4. DECLARE @TmpTable TABLE (ID INT, TEXTVal VARCHAR(100))
  5. INSERT TestTable (ID, TEXTVal)
  6. OUTPUT Inserted.ID, Inserted.TEXTVal INTO @TmpTable
  7. VALUES (1,'FirstVal')
  8. INSERT TestTable (ID, TEXTVal)
  9. OUTPUT Inserted.ID, Inserted.TEXTVal INTO @TmpTable
  10. VALUES (2,'SecondVal')
  11. SELECT * FROM @TmpTable
  12. SELECT * FROM TestTable
  13. DROP TABLE TestTable
  14. GO
  1. USE AdventureWorks;
  2. GO
  3. CREATE TABLE TestTable (ID INT, TEXTVal VARCHAR(100))
  4. INSERT TestTable (ID, TEXTVal)
  5. OUTPUT Inserted.ID, Inserted.TEXTVal
  6. VALUES (1,'FirstVal')
  7. INSERT TestTable (ID, TEXTVal)
  8. OUTPUT Inserted.ID, Inserted.TEXTVal
  9. VALUES (2,'SecondVal')
  10. DROP TABLE TestTable
  11. GO

二.带有OUTPUT的DELETE的应用.

如果要删除数据的同时,还需要记录日志,或者归档数据.在DELETE中使用OUTPUT子句在适合不过了.

  1. USE AdventureWorks;
  2. GO
  3. CREATE TABLE TestTable (ID INT, TEXTVal VARCHAR(100))
  4. DECLARE @TmpTable TABLE (ID INT, TEXTVal VARCHAR(100))
  5. INSERT TestTable (ID, TEXTVal)
  6. VALUES (1,'FirstVal')
  7. INSERT TestTable (ID, TEXTVal)
  8. VALUES (2,'SecondVal')
  9. DELETE
  10. FROM TestTable
  11. OUTPUT Deleted.ID, Deleted.TEXTVal INTO @TmpTable
  12. WHERE ID IN (1,2)
  13. SELECT * FROM @TmpTable
  14. SELECT * FROM TestTable
  15. DROP TABLE TestTable
  16. GO

三.带有OUTPUT的UPDATE的应用

  1. USE AdventureWorks;
  2. GO
  3. CREATE TABLE TestTable (ID INT, TEXTVal VARCHAR(100))
  4. DECLARE @TmpTable TABLE (ID_New INT, TEXTVal_New VARCHAR(100),ID_Old INT, TEXTVal_Old VARCHAR(100))
  5. INSERT TestTable (ID, TEXTVal)
  6. VALUES (1,'FirstVal')
  7. INSERT TestTable (ID, TEXTVal)
  8. VALUES (2,'SecondVal')
  9. UPDATE TestTable
  10. SET TEXTVal = 'NewValue'
  11. OUTPUT Inserted.ID, Inserted.TEXTVal, Deleted.ID, Deleted.TEXTVal INTO @TmpTable
  12. WHERE ID IN (1,2)
  13. SELECT * FROM @TmpTable
  14. SELECT * FROM TestTable
  15. DROP TABLE TestTable
  16. GO

带有OUTPUT的INSERT,DELETE,UPDATE的更多相关文章

  1. sql server 带有OUTPUT的INSERT,DELETE,UPDATE

    原文:sql server 带有OUTPUT的INSERT,DELETE,UPDATE OUTPUT是SQL SERVER2005的新特性.可以从数据修改语句中返回输出.可以看作是"返回结果 ...

  2. Use Select To Generate Any Insert/Delete/Update Statement

    If you don't have the permission to generate script according to an existing db, but you have the re ...

  3. sqlserver触发器insert,delete,update

    Create Trigger [dbo].[upemployee_kefyu_sale] on [dbo].[employee] for update as if update(FullName) b ...

  4. MySQL进阶10--DML数据操纵预言: insert/delete/update --多表连接修改/.多表连接删除/多表连接查询-- truncate 和 delete的区别

    /* DML -- 数据操纵预言: insert/delete/update */ #一: 插入语句 /* 语法1: insert into 表名(列名,..,列名....) values(值1,值2 ...

  5. OUTPUT 在insnert delete update 的神奇功效

    Inserted   deleted  个人理解 应该是两个 临时表   分别存储 变动后的数据集  和  变动前的数据集 使用例子: 1.对于INSERT,可以引用inserted表以查询新行的属性 ...

  6. 触发器内insert,delete,update判断执行不同的内容

    create trigger tr_aon afor insert,update,delere asbegin IF EXISTS(SELECT 1 FROM inserted) AND NOT EX ...

  7. MyBatis insert/delete/update 的返回值

    insert,返回值是:新插入行的主键(primary key):需要包含<selectKey>语句,才会返回主键,否则返回值为null. <insert id="inse ...

  8. executenonquery只对insert,delete,update有效,查询select会默认返回-1

    问题:cmd.ExecuteNonQuery() 方法总是返回-1 原因:ExecuteNonQuery() 方法 select 返回-1 解释:执行Select子句,数据库并无变化,自然返回-1同样 ...

  9. sql server中带有output的DML

    OUTPUT是SQL SERVER2005的新特性.可以从数据修改语句中返回输出.可以看作是"返回结果的DML".INSERT,DELETE,UPDATE均支持OUTPUT子句.在 ...

随机推荐

  1. 关于Keil C51中using关键字的使用心得

    刚才看到一位很牛的师兄写的一篇日志中提到了Keil C51中using这个关键字的用法,粗心的我本来一直都没有留意它是用来干嘛的(因为我一般看见它都是在中断服务函数的定义开头处,好像没有了它也可以中断 ...

  2. 数据可视化的优秀入门书籍有哪些,D3.js 学习资源汇总

    习·D3.js 学习资源汇总 除了D3.js自身以外,许多可视化工具包都是基于D3开发的,所以对D3的学习就显得很重要了,当然如果已经有了Javascript的经验,学起来也会不费力些. Github ...

  3. PSPInstance Object | Web Python

    PSPInstance Object | Web Python The PSPInstance object is available to all PSP pages through the psp ...

  4. Linux NFS服务器的安装与配置(转载)

    一.NFS服务简介 NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布.功能是通过网络让不同的机器.不同的操 ...

  5. 使用Comparable接口的小例子

    代码: public class Student implements Comparable<Student> { private int id; private String name; ...

  6. 【Android开发经验】LayoutInflater—— 你可能对它并不了解甚至错误使用

    今天,看到了一篇文章讲LayoutInflater的使用方法.瞬间感觉自己对这个类确实不够了解,于是简单的看了下LayoutInflater类的源码.对这个类有了新的认识. 首先.LayoutInfl ...

  7. nand烧写分析/内核在启动过程中式如何将这个文件映射成/目录及各子目录的?

    我用的是ramdisk.image.gz,烧写在flash的0x10140000处 我不太明白内核在启动过程中式如何将这个文件映射成/目录及各子目录的? 如果ramdisk.image.gz在flas ...

  8. bootstrap之Flick

    Flick package io.appium.android.bootstrap.handler; import com.android.uiautomator.core.UiDevice; imp ...

  9. java学习笔记day04

    1.static关键字  特点:1)随着类的加载而加载        2)优先于对象存在        3)被所有对象所共享        4)可以直接被类名调用(类名.静态成员) 注意:静态方法只能 ...

  10. 【原创】System.Data.SQLite内存数据库模式

    对于很多嵌入式数据库来说都有对于的内存数据库模式,SQLite也不例外.内存数据库常常用于极速.实时的场景,一个很好的应用的场景是富客户端的缓存数据,一般富客户端的缓存常常需要分为落地和非落地两种,而 ...