快速业务通道

SQLServer数据库技术(66)

作者 佚名技术 来源 数据库编程 浏览 发布时间 2012-03-20

11.2.1 DELETE 语法
DELETE 语句用来从表中删除数据,其语法为:





各参数说明如下:

  • FROM
    此参数为可选选项,用于连接DELETE 关键字和要删除数据的对象名称。
  • table_name
    指定要删除数据的表。
  • WITH ( [...n])
    指定一个或多个目标表允许的表提示。
  • view_name
    指定用于删除数据的视图。
  • rowset_function_limited
    行集合函数限制,即使用OPENQUERY() 或OPENROWSET() 函数。
  • FROM
    指定一个额外的FROM 子句。这是DELETE 命令在Transact-SQL 语言中的扩展,它允许同时删除多个表中的数据。其所含的参数包括join_table、 join_type 等,与第10 章“数据查询”中FROM 子句中所讲的一致。
  • WHERE
    指定限制数据删除的条件。如果不指定WHERE 子句,就会删除表中的所有数据。在 WHERE 子句中指定两种形式的删除操作。一种是搜索删,除即使用搜索条件来限定要删除的数据行:另一种是定位删除,即使用CURRENT OF 子句来指定一个游标,删除操作会在游标的当前位置产生。定位删除比搜索删除更精确。
  • GLOBAL
    说明要使用的游标是全局游标。如果不使用此选项,而又存在一个全局游标和一个局部游标同名的情况时,系统认为所选择的游标是局部游标。
  • cursor_name
    指定打开的游标名称。此游标必须是允许更新的。
  • cursor_variable_name
    指定游标变量的名称。此游标变量必须是允许更新的。
  • OPTION ( [,...n] )
    请参见第10 章“数据查询”中OPTION 子句中所讲述的参数。
  • table_hint
    表提示用于指定一个表的扫描计划,即将要用于查询优化器的一个或多个索引,或一个用于检索数据的锁定方法。此选项一般来说不必使用,查询优化器会自动选择一个最优的执行方案。各表提示之间应使用逗号隔开。
  • INDEX(index_val [,...n])
    指定索引提示,即当执行命令时由SQL Server 使用的索引的名称或ID 号。每个表只能指定一个索引提示。在表提示中最多可以指定250 非簇索引。
  • FASTFIRSTROW
    等价于OPTION (FAST 1) ,即对第一行返回数据采用查询优化。
  • HOLDLOCK
    一般情况下,当执行SELECT 命令时,SQL Server 会在选取数据的过程中对该数据所属的数据页设定一个共享锁(Shared Lock, 关于锁的介绍请参见本章后部分)。当SQL Server 读到下一个数据页的数据时,上一个数据页的共享锁就会被解除。但如果使用了 HOLDLOCK 选项,则在整个SELECT 命令执行的过程中设定的共享锁会一直存在。此选项不能在带FOR BROWSE 子句的SELECT 语句中使用。此选项等价于SERIALIZABLE 选项。
  • NOLOCK
    一般情况下,当执行SELECT 命令时,SQL Server 会在选取数据的过程中对该数据所属的数据页设定一个共享锁(Shared Lock, 关于锁的介绍请参见本章后部分)。但如果使用了NOLOCK 选项,则SQL Server 不会指定共享锁,而且不管其它用户是否正在更改所读取的数据,SELECT 命令仍然可以读取数据。因此,使用此选项可能会读取到其它用户尚未提交的数据。此选项等价于READUNCOMMITTED 选项。
  • PAGLOCK
    指定在SELECT 命令执行时使用对数据页做共享锁。这是SQL Server 的内定方式。
  • READCOMMITTED
    指定数据扫描执行时使用与运行在READ COMMITTED 孤立级上的事务相同的锁语义。即SELECT 命令不会返回尚未提交的数据。
  • READPAST
    跳过目前被锁定的行。此选项只用于在事务运行在READ COMMITTED 孤立级上的情况下。
  • READUNCOMMITTED
    此选项等价于NOLOCK 选项。
  • REPEATABLEREAD
    指定数据扫描执行时使用与运行在REPEATABLE READ 孤立级上的事务相同的锁语义。即用SELECT 命令读取的数据在整个命令执行过程中不会被更改。此选项会影响系统的效能,非必要情况最好不用此选项。
  • ROWLOCK
    指定使用共享的行数据锁,即使用行级别锁定。
  • SERIALIZABLE
    此选项等价于HOLDLOCK 选项。
  • TABLOCK
    指定用SELECT 命令读取数据时对所选取的表的全部数据做锁定,直到整个命令执行完毕。如果指定了HOLDLOCK 选项,则共享的表锁定会维持到事务结束。
  • TABLOCKX
    指定用SELECT 命令读取数据时对所选取的表的全部数据做锁定,直到整个命令或事务执行完毕。
  • UPDLOCK
    指定在SELECT 命令执行时使用更新锁(Update Lock),而不使用共享锁,并且此更新锁将维持到命令执行结束为止。

如果省略WHERE子句,则表示删除表中的全部数据,但表的定义仍在数据库中,也就是说,DELETE子句删除的是表中的数据,而不是关于表的定义。 NOLOCK、READUNCOMMITIED或READPAST表提示不能用于作为插入、删除或更新操作对象的表。

[1] [2] 下一页

关注此文的读者还看过:
  • 2010-4-1 18:12:45 预防非法表D99_Tmp,kill_kk的建立
  • 2008-4-23 15:53:39 SQL Server数据库超级管理员账号防护知识
  • 2008-4-11 21:37:35 SQL Server 2005数据库镜像配置脚本示例
  • 2008-4-4 9:12:54 讲解如何实现互联网上数据库的安全
  • 2008-4-1 11:07:24 SQL 2005数据库转到SQL 2000的步骤讲解
  • 2008-3-31 12:39:45 SQL Server自动生成日期加数字的序列号
  • 2008-3-31 12:39:07 SQL Server 2000的数据库容量究竟是多大
  • 2008-3-18 18:01:49 SQL Server 2005数据库的同义词Bug 讲解

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号