网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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语句(删除重复记录,收.
.修复SQLSERVER2000数据库之实战经.
.sql语句操作之cv大法全集.
.对外连接的表加上条件后将会使外.
.讲解V$Datafile_Header相关字段的.
.个人经验总结:SQL Server数据库.
.SQL Server 2008综合数据可编程性.
.数据库完整性就是数据库完整性约.
.分页SQLServer存储过程 .
.详细介绍查询优化技术在现实系统.
.诊断全局错误时如何在系统级进行.
.由浅入深讲解SQL Server 2005数据.
.用SQL数据库批量插入数据简介.
.如何恢复系统数据库如何恢复系统.
.关于MSSQL占用过多内存的问题.
.在SQL Server 2000里设置和使用数.
.快速解决日志文件满造成的无法写.
.SQL SERVER应用问题解答13例(一.
.在SQL Server 中使用SQLDMO.
.SQL Server 2005性能测试实践-CP.

解读SQL Server2008的新语句MERGE

发表日期:2007-7-21


  SQL Server 2008将包含用于合并两个行集(rowset)数据的新句法。根据一个源数据表对另一个数据表进行确定性的插入、更新和删除这样复杂的操作,运用新的MERGE语句,开发者用一条命令就可以完成。

  对两个表进行信息同步时,有三步操作要进行。首先要处理任何需要插入目标数据表的新行。其次是处理需要更新的已存在的行。最后要删除不再使用的旧行。这个过程中需要维护大量重复的逻辑,并可能导致微妙的错误。

  Bob Beauchemin讨论了MERGE语句,这个语句将上述的多个操作步骤合并成单一语句。他给出了如下的例子:

以下是引用片段:

merge [target] t
using [source] s on t.id = s.id
when matched then update t.name = s.name, t.age = s.age -- use "rowset1"
when not matched then insert values(id,name,age) -- use "rowset2"
when source not matched then delete; -- use "rowset3"
 
  如你所见,具体操作是根据后面的联合(join)的解析结果来确定的。在这个例子中,如果目标和源数据表有匹配的行,就实行更新操作。如果没有,就实行插入或者删除操作来使目标数据表和源数据表保持一致。

  这个新句法的一个美妙之处是它在处理更新时的确定性。在使用标准的UPDATE句法和联合时,可能有超过一个源行跟目标行匹配。在这种情况下,无法预料更新操作会采用哪个源行的数据。

  而当使用MERGE句法时,如果存在多处匹配,它会抛出一个错误。这就提醒了开发者,要达到预想的目标,当前的联合条件还不够明确。

上一篇:安装Ms SQL Server 2005 开发版时出现性能计数器要求安装错误的解决办法 人气:4509
下一篇:SQL Server 2005(32 位)系统要求 人气:3846
浏览全部SQL Server2008的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐