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表提示不能用于作为插入、删除或更新操作对象的表。

  11.2.2 用DELETE 删除数据

  (1) 删除一条记录

  例11-5 删除编号为‘10031011 ’的员工记录

  use pangu

  delete from employee

  where emp_id = ’10031011’

  (2) 删除多条记录

  例11-6 删除所有的部门信息记录

  use pangu

  delete from department_info /* 或使用 delete department_info */

  这个例子删除了department_info 表中的所有数据使它成为空表

  (3) 带子查询的删除语句

  子查询同样可以嵌套在DELETE 语句中,用以构造执行删除操作的条件。

  例11-7: 删除后勤部所有员工的记录。

  use pangu

  delete from employee

  where dept_id =

  (select dept_id

  from department

  where d_name = ’后勤部’)

  例11-8 删除订货表前100 项记录中所有产品编号为1003002 的产品

  use pangu

  delete orders

  from (select top 100 * from orders) as orders_ top100

  where orders.p_id = orders_ top100.p_id

  (4) 删除当前游标行数据

  例11-9: 删除游标dinfo_cursor 所指定的数据行。

  delete from department_info

  where current of dinfo_cursor

11.2.3 TRUNCATE TABLE 命 令

  如果要删除表中的所有数据,那么使用TRUNCATE TABLE 命令比用DELETE 命令快得多。因为DELETE 命令除了删除数据外,还会对所删除的数据在事务处理日志中作记录,以防止删除失败时可以使用事务处理日志来恢复数据;而TRUNCATE TABLE 则只做删除与表有关的所有数据页的操作。TRUNCATE TABLE 命令功能上相当于使用不带WHERE 子句的DELETE 命令。但是TRUNCATE TABLE 命令不能用于被别的表的外关键字依赖的表。

  TRUNCATE TABLE 命令语法如下:

  TRUNCATE TABLE table_name

  注意:由于TRUNCATE TABLE命令不会对事务处理日志进行数据删除记录操作,因此不能激活触发器。

  例11-10: 删除所有的部门信息记录。

  use pangu

  truncate table department_info

转载于:https://www.cnblogs.com/Athrun/archive/2007/07/27/833189.html

MS SQL入门基础:删除数据相关推荐

  1. MS SQL入门基础:删除数据库

    6.5.1 用Enterprise Manager 删除数据库 在Enterprise Manager 中在所要删除的数据库上单击右键,从快捷菜单中选择"删除(Delete)"选项 ...

  2. MS SQL入门基础:数据查询--SELECT语句

    数据库是为更方便有效地管理信息而存在的人们,希望数据库可以随时提供所需要的数据信息.因此,对用户来说,数据查询是数据 库最重要的功能.本章将讲述数据查询的实现方法. 在数据库中,数据查询是通过SELE ...

  3. MS SQL入门基础:打开游标

    打开游标游标在声明以后,如果要从游标中读取数据必须打开游标.打开一个Transact-SQL服务器游标使用OPEN 命令,其语法规则为: OPEN { { [GLOBAL] cursor_name } ...

  4. MS SQL入门基础:备份和恢复系统数据库

    系统数据库保存了有关SQL Server 的许多重要数据信息,这些数据的丢失将给系统带来极为严重的后果,所以我们也必须对系统数据库进行备份.这样一旦系统或数据库失败,则可以通过恢复来重建系统数据库.在 ...

  5. MS SQL入门基础:管理触发器

    如果要显示作用于表上的触发器究竟对表有哪些操作,必须查看触发器信息.在MS SQL Server 中,有多种方法查看触发器信息.在本节我们将介绍两种常用的方法,即通过MS SQL Server 的管理 ...

  6. MS SQL入门基础:存储过程概述

    在大型数据库系统中,存储过程和触发器具有很重要的作用.无论是存储过程还是触发器,都是SQL 语句和流程控制语句的集合.就 本质而言,触发器也是一种存储过程.存储过程在运算时生成执行方式,所以,以后对其 ...

  7. MS SQL入门基础:查看表

    7.5.1 查看表的属性 在Enterprise Manager 中,用右键单击要查看属性的表,从快捷菜单中选择"属性(Properties)"选项,则会出现如图7-6 所示的表的 ...

  8. MS SQL入门基础:数据库中的锁

    11.5.1 锁的概念 锁(Lock) 是在多用户环境下对资源访问的一种限制.机制当对一个数据源加锁后,此数据源就有了一定的访问限制.我们就称对此数据源进行了"锁定".在SQL S ...

  9. MS SQL入门基础:移动数据库

    在SQL Server 中可以使用拆分(Detach)和附加(Attach)的方法来移动数据库.拆分数据库是从服务器中移去逻辑数据库,但不会将操作系统中的数据库文件删除.附加数据库将会创建一个新的数据 ...

最新文章

  1. 走进 San CLI(下):实现原理
  2. mybatis Example 使用方法
  3. 机器学习1---基本概念
  4. Nginx 用户认证
  5. Aqua - Mac OS X平台的用户界面(user interface)
  6. 【Luogu2393】yyy loves Maths II(浮点输入输出)
  7. 结合Cookie的简单图片验证码的工作原理探究
  8. 帮助用户连接网络打印机工具
  9. 【FPGA】组合逻辑 3-8译码器实现
  10. 圆角半角数据库_MySQL存储全角字符和半角字符的区别
  11. WIN 10 FTP 不好用问题总结
  12. excel 筛选重复项_列表项的Excel筛选器:2011年“鲨鱼周”
  13. 与繁重的工作一起修行
  14. 阿里云播放器AliyunPlayer的走马灯组件的位置
  15. ue4开关门点击时onclicked事件没有触发的解决方案
  16. 解决谷歌浏览器打开控制台有延迟
  17. 河南本科计算机科学与技术排名,河南计算机科学与技术专业大学排名
  18. 搭建基础后台框架及整合Swagger2及整合mybatisPlus代码器
  19. 泪目,不枉费挑灯夜战两个月,终于拿到offer了,集合 +Spring+JVM+ 并发 +Redis 总结
  20. 人脸检测,关键点识别,人脸对齐

热门文章

  1. windows下GIT使用记录--00准备阶段
  2. 软件包 sun-java6-jdk 没有可供安装的候选者
  3. WSS 3.0 Object Model
  4. 在moss页面出错时,显示详细的错误信息.
  5. samli文件_5.3 smali文件格式
  6. JQuery环境配置
  7. php 对象里还有哪些对象_PHP面向对象(OOP)之实例化对象的方法
  8. python web自动化_Selenium+Python Web自动化
  9. PHP 8 确认支持 JIT
  10. js网页如何获取手机屏幕宽度