zoukankan      html  css  js  c++  java
  • 15.更新和删除数据--SQL

    一、更新数据


    更新(修改)表中的数据,可以使用UPDA TE语句。有两种使用UPDA TE的方式:

    • 更新表中的特定行;
    • 更新表中的所有行。

    警告:不要省略WHERE子句
      在使用UPDA TE时一定要细心。因为稍不注意,就会更新表中的所有行。
    提示:UPDATE与安全
      在客户端/服务器的DBMS中,使用UPDA TE语句可能需要特殊的安全权限。在你使用UPDA TE前,应该保证自己有足够的安全权限。

    基本的UPDA TE语句由三部分组成,分别是:

    • 要更新的表;
    • 列名和它们的新值;
    • 确定要更新哪些行的过滤条件。
    UPDATE Customers
    SET cust_email = 'kim@thetoystore.com'
    WHERE cust_id = '1000000005';

    二、删除数据


     

    使用DELETE语句。有两种使用DELETE的方式:

    • 从表中删除特定的行;
    • 从表中删除所有行。

    警告:不要省略WHERE子句
      在使用DELETE时一定要细心。因为稍不注意,就会错误地删除表中所有行。在使用这条语句前,请完整地阅读本节。
    提示:DELETE与安全
      在客户端/服务器的DBMS中,使用DELETE语句可能需要特殊的安全权限。在你使用DELETE前,应该保证自己有足够的安全权限。

    DELETE FROM Customers
    WHERE cust_id = '1000000006';

    提示:友好的外键
      简单联结两个表只需要这两个表中的常用字段。也可以让DBMS通过使用外键来严格实施关系(这些定义在附录A
    中)。存在外键时,DBMS使用它们实施引用完整性。例如要向Products表中插入一个新产品,DBMS不允许通过未知的供应商id插入它,
    因为vend_id列是作为外键连接到Vendors表的。那么,这与DELETE有什么关系呢?使用外键确保引用完整性的一个好处是,DBMS通常可
    以防止删除某个关系需要用到的行。例如,要从Products表中删除一个产品,而这个产品用在OrderItems的已有订单中,那么DELETE语句
    将抛出错误并中止。这是总要定义外键的另一个理由。


    提示:FROM关键字
      在某些SQL实现中,跟在DELETE后的关键字FROM是可选的。但是即使不需要,也最好提供这个关键字。这样做将保证SQL代码在DBMS之间可移植。
    DELETE不需要列名或通配符。DELETE删除整行而不是删除列。要删除指定的列,请使用UPDA TE语句。


    说明:删除表的内容而不是表
      DELETE语句从表中删除行,甚至是删除表中所有行。但是,DELETE不删除表本身。
     
    提示:更快的删除
    如果想从表中删除所有行,不要使用DELETE。可使用TRUNCA TE TA BLE语句,它完成相同的工作,而速度更快(因为不记录数据的变
    动)。

    三、更新和删除的指导原则


    下面是许多SQL程序员使用UPDA TE或DELETE时所遵循的重要原则。

    • 除非确实打算更新和删除每一行,否则绝对不要使用不带WHERE子句的UPDA TE或DELETE语句。
    • 保证每个表都有主键(如果忘记这个内容,请参阅第12课),尽可能像WHERE子句那样使用它(可以指定各主键、多个值或值的范围)。
    • 在UPDA TE或DELETE语句使用WHERE子句前,应该先用SELECT进行测试,保证它过滤的是正确的记录,以防编写的WHERE子句不正确。
    • 使用强制实施引用完整性的数据库(关于这个内容,请参阅第12课),这样DBMS将不允许删除其数据与其他表相关联的行。
    • 有的DBMS允许数据库管理员施加约束,防止执行不带WHERE子句的UPDA TE或DELETE语句。如果所采用的DBMS支持这个特性,应该使用它。

    若是SQL没有撤销(undo)按钮,应该非常小心地使用UPDA TE和DELETE,否则你会发现自己更新或删除了错误的数据。

  • 相关阅读:
    5610连接MMMB并显示隐藏文件夹的方法
    C#使用DataAdapter访问Sql Server
    类型初始值设定项引发异常
    Css制作table细线表格
    An odd couple comedy
    【原创】SDK的学习方法
    科技创新项目小程序设计(1)(07年10月5日)
    科技创新项目小程序设计(4)(07年11月17日)
    科技创新项目小程序设计(2)(07年10月12日)
    欢迎加入 CAD,CAE软件开发与算法研究 团队博客
  • 原文地址:https://www.cnblogs.com/lbonet/p/7561069.html
Copyright © 2011-2022 走看看