首页 > 开发 > 综合 > 正文

删除数据

2024-07-21 02:12:59
字体:
来源:转载
供稿:网友
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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表