网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > SQL技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.一种处理不规范日期数据的好方法.
.内嵌或嵌入SQL和存储过程之对比.
.快速清除SQLServer日志的两种方法.
.利用视图管理器编写高效 SQL SEL.
.初学者需要掌握的数据库设计词汇.
.SQL SERVER数据导成INSERT.
.SQL Server 某些条件下求某日的日.
.在SQLServer中怎么样恢复数据的存.
.讲解数据库调优与程序员相关的几.
.SQL各种写法的效率问题.
.在Windows xp系统上安装了SQL se.
.使用存储过程时一个错误的解决方.
.SQL Server 性能调优.
.XML文件导入SQL Server 2000.
.循序渐进讲解Informix SQL的十一.
.在SQL Server中快速删除重复记录.
.数据访问-与数据库建立连接.
.sql server中如何计算农历.
.SQL Server2000 索引结构及其使用.
.Sql2005如何用dtexec运行ssis(DT.

SQL Server 2005数据库中的Output子句

发表日期:2008-5-29


这篇论坛文章(赛迪网技术社区)主要介绍了SQL Server 2005中Output子句的使用方法,更多内容请参考下文:

SQL Server 2005中的output子句,可以使你从修改语句(INSERT、UPDATE、DELETE)中将数据返回到表变量中。带结果的 DML 的有用方案包括清除和存档、消息处理应用程序以及其他方案。这一新的 OUTPUT 子句的语法为:

OUTPUT INTO @table_variable

可以通过引用插入的表和删除的表来访问被修改的行的旧/新映像,其方式与访问触发器类似。在 INSERT 语句中,只能访问插入的表。在 DELETE 语句中,只能访问删除的表。在 UPDATE 语句中,可以访问插入的表和删除的表。下面选用MSDN的例子介绍之:

作为带结果的 DML 可能有用的清除和存档方案的示例,假设你具有一个大型的 Orders 表,并且希望定期清除历史数据。你还希望将清除的数据复制到一个名为 OrdersArchive 的存档表中。你声明了一个名为 @DeletedOrders 的表变量,并且进入一个循环,在该循环中,你使用上文中的“TOP 增强功能”一节中描述的清除方法,成块地删除了历史数据(比如,早于 2003 年的定单)。这里增加的代码是 OUTPUT 子句,它将所有被删除的行的所有属性复制到 @DeletedOrders 表变量中,然后,使用 INSERT INTO 语句将该表变量中的所有行复制到 OrdersArchive 表中:

DECLARE @DeletedOrders TABLE

(

orderid INT,

orderdate DATETIME,

empid INT,

custid VARCHAR(5),

qty INT

)

WHILE 1=1

BEGIN

BEGIN TRAN

DELETE TOP(5000) FROM Orders

OUTPUT deleted.* INTO @DeletedOrders

WHERE orderdate < '20030101'

INSERT INTO OrdersArchive

SELECT * FROM @DeletedOrders

COMMIT TRAN

DELETE FROM @DeletedOrders

IF @@rowcount < 5000

BREAK

END

再举一个例子如下,假如有表如下

Create table Employee(EmpID int identity(1, 1) constraint Employee_pk primary key, FirstName varchar(100), LastName Varchar(100), Sex char(1), Salutation as case when Sex ='M' then 'Mr.' when Sex ='F' then 'Ms.' else '' end, Salary Money, Deductions as case When Salary <3000 then .20 * Salarywhen Salary between 30000 and 50000 then .26*Salary when Salary between 50001 and 75000 then .30*Salaryelse .35*Salary end, DOJ datetime constraint DOJ_DEF default getdate())

很容易的一个表,其中用到了case子句,分别对Salutation ,deductions,doj等进行了设置。而我们可以再搞一个存储过程,如下:

Create procedure employee_insert@Fname varchar(100),@Lname varchar(100),@sex char(1),@Salary Moneyasdeclare @empoutput table (EmpID int ,FirstName varchar(100), LastName Varchar(100),Sex char(1), Salutation char(3),Salary Money,Deductions Money,DOJ datetime )insert into Employee(FirstName,LastName,Salary,sex)OUTPUT inserted.* into @empoutputvalues(@Fname ,@Lname ,@Salary,@sex )Select * from @empoutput

然后在调用该存储过程时,可以这样来用USE [MyDatabase]

GOexec employee_insert 'Miho','Yoshikawa','F',146000

这样,将在执行的时候,将往employee表里插入数据,并且,将定义了一个临时的变量empoutput,注意哦,这个可以以表的形式定义的,这里很容易看的出来,并且,将插入到employee表的数据同时输出到这个empoutput变量中去.我们执行这个存储过程后,会发现如下结果

EmpID,FirstName,LastName,Sex,Salutation,Salary,Deductions,DOJ

7,Miho,Yoshikawa,F,Ms.,146000.00,51100.00,2006-04-09 23:16:44.920

,并且employee表中的确插入了记录

-------------------------------------------------------------------------------------

调用带有Output参数的存储过程.txt

CREATE PROCEDURE SP_RealTimeDisplay

(

@FromEmp nvarchar(20),

@FromDep nvarchar(20),

@i1 nvarchar(20) output,

@i2 nvarchar(20) output,

@i3 nvarchar(20) output

)

AS

set nocount on

--公司批复

select @i1=(Select count(FsignID) as Sum1 From T_MessageSignature Where FSignID=@FromEmp and FLastSignID=1 and FSignRemark is null)

--会签意见

select @i2=(Select count(FsignID) as Sum1 From T_MessageSignature Where FSignID=@FromEmp and FLastSignID=0 and FSignRemark is null)

--考勤审批

select @i3=(Select count(FKaoQinID) as Sum1 From T_KaoQin Where FDepID Like @FromDep and FCheckerID=0)

GO

--调用,先定义再输出

DECLARE @a nvarchar(20)

DECLARE @b nvarchar(20)

DECLARE @c nvarchar(20)

Execute SP_RealTimeDisplay '106000003','012708%',@a output,@b output,@c output

select @a as aa, @b as bb,@c as cc

上一篇:讲解SQL Server数据库中函数的使用方法 人气:973
下一篇:根据版本的不同整理所有的绿色SQL Server 人气:992
浏览全部SQL Server 2005的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐