数据更新包括了表存在的情况下数据的添加,数据的删除和数据的更新,主要是下面三个语句:

  1. INSERT 语句
  2. DELETE 语句
  3. UPDATE 语句

在本章的最后,讲了关于「事务」的相关知识,用于对作出的更改进行决定——是否上交或者舍弃改动.

INSERT 语句

基本语法

INSERT INTO <tablename> (column1, column2, column3, ....)
VALUES (value1, value2, value3, ...);

术语:

  1. 清单:在 SQL 中,“ () ”称为「清单」,其中包含列名的叫做「列清单」
  2. VALUE 子句
  3. 值清单: VALUE 子句后为值清单

注意:

  1. 可以省略列清单
  2. 添加 NULL 值的时候,在值清单中加入 NULL

DEFAULT 关键字

在创建表格的时候,可以使用 DEFAULT 约束,例如:

CREATE TABLE ProductIns 
(sale_price INTEGER DEFAULT 0,
...);

在 VALUE 子句的清单中可指定 DEFAULT 关键字,例如:

INSERT INTO ProductIns VALUES ('0007', ‘擦菜板’,‘厨房用具’, DEFAULT, 790, '2009-04-28');

INSERT...SELECT — 从其他表中复制数据

格式

(举例为从 Product 复制数据到 ProductCopy 表中)

INSERT INTO ProductCopy
SELECT product_id, product_name. ...
FROM Product;

其中的 SELECT 语句

包含 SELECT 语句的 INSERT 语句, SELECT 语句中可以添加 WHERE 子句和 GROUP BY 子句.

DELETE 语句

定义:

DELETE 语句用于删除表中的记录(行).

清空整张表

有三种方法清空整张表,其中 TRUNCATE 速度最快:

  1. DELETE FROM ;
  2. TRUNCATE  ;
  3. DROP ;

指定条件的 DELETE 语句

DELETE .... WHERE
注意:
由于DELETE 只能删除记录,因此不能使用 GROUP BY 等子句.

UPDATE 语句

格式

UPDATE <tablename>
SET <columnname> = <expression>;

其中更新的值都记录在 SET 子句中.

指定条件的 UPDATE 语句

UPDATE...WHERE...

多列更新

定义:当对于满足同一条件的数据进行多条更新的时候,可以使用多列更新的方法:
有两种方式可以进行多列更新.

方法1:将列分隔排列

UPDATE Product 
SET sale_price = sale_price * 10,
purchase_price = purchase_price / 2
WHERE product_type = '厨房用具‘.

方法2:将列清单化

UPDATE Product 
SET (sale_price ,purchase_price) = (sale_price * 10,
purchase_price = purchase_price / 2)
WHERE product_type = '厨房用具‘.

事务

定义:

需要在统一处理单元中执行的一系列变更处理的集合叫做事务.

使用指令创建事务的语法

  1. 开始事务:BEGIN TRANSACTION;
  2. 提交处理:COMMIT
    取消处理: ROLLBACK

不使用指令时创建事务的模式

DBMS 有两种模式:

  1. 自动提交模式:每条 SQL 语句就是一个事务
  2. 直到用户执行 COMMIT 或者 ROLLBACK 为一个事务

ACID 特性

DBMS 都遵循 ACID 特性.它们分别是:

  1. Atomicity 原子性
  2. Consistency 一致性
  3. Isolation 隔离性
  4. Durability 持久性

《SQL 基础教程》第四章:数据更新的更多相关文章

  1. 《SQL 基础教程》第二章:查询基础

    这一章的结构如下: SELECT 语句基础 算术运算符和比较运算符 逻辑运算符 SELECT 语句可用于查询数据,并且可以设定条件来查询具有特定值的记录.条件的设定就需要算数运算符.比较运算符和逻辑运 ...

  2. 《SQL 基础教程》—第一章:数据库与 SQL

    导言 这一章的内容如下: 数据库简介 SQL 概要 表的创建 表的删除与更新 数据库简介 定义: Database, 是大量数据的集合Database Management System,是用于管理数 ...

  3. 《SQL基础教程》+ 《SQL进阶教程》 学习笔记

    写在前面:本文主要注重 SQL 的理论.主流覆盖的功能范围及其基本语法/用法.至于详细的 SQL 语法/用法,因为每家 DBMS 都有些许不同,我会在以后专门介绍某款DBMS(例如 PostgreSQ ...

  4. [SQL基础教程] 4-4 事务

    [SQL基础教程] 4 数据更新 4-4 事务 事务 需要在同一处理单元中执行的一系列更新处理的集合 创建事务 事务开始语句; DML语句1; DML语句2; . . . 事务结束语句; 事务开始语句 ...

  5. [SQL基础教程] 4-3 数据的更新(UPDATE)

    [SQL基础教程] C4 数据更新 4-3 数据的更新(UPDATE) UPDATE UPDATE <表名> SET <列名> = <表达式>; UPDATE &l ...

  6. [SQL基础教程] 4-2 数据删除(DELETE)

    [SQL基础教程] C4 数据更新 4-2 数据删除(DELETE) DROP TABLE / DELETE DROP TABLE - 完全删除表 DELETE - 仅删除数据,保留表容器 DELET ...

  7. [SQL基础教程] 4-1 数据的插入(INSERT)

    [SQL基础教程] C4 数据更新 4-1 数据的插入(INSERT) INSERT INSERT INTO <表名>(列1,列2...) VALUES(值1,值2...); 清单 用() ...

  8. 推荐《SQL基础教程(第2版)》中文PDF+源代码+习题答案

    我认为<SQL基础教程(第2版)>非常适合数据库学习的初学者.论述的角度是读者的角度,会换位思考到读者在看到这一段时候会发出怎样的疑问,非常难得:原始数据的例题只有一道,但是可以反复从不同 ...

  9. Objective-C 基础教程第三章,面向对象编程基础知

    目录 Objective-C 基础教程第三章,面向对象编程基础知 0x00 前言 0x01 间接(indirection) 0x02 面向对象编程中使用间接 面向过程编程 面向对象编程 0x03 OC ...

  10. [Learn Android Studio 汉化教程]第四章 : Refactoring Code

    [Learn Android Studio 汉化教程]第四章 : Refactoring Code 第四章 Refactoring Code    重构代码 在Android Studio中开发,解决 ...

随机推荐

  1. C和C指针小记(十四)-字符串、字符和字节

    1.字符串 C语言没有字符串数据类型,因为字符串以字符串常量的形式出现或存储于字符数组中. 字符串常量和适用于那些程序不会对他们进行修改的字符串. 所有其他字符串都必须存储于字符串数组或动态分配的内存 ...

  2. InnoDB中锁的模式

    Ⅰ.总览 S行级共享锁 lock in share mode X行级排它锁 增删改 IS意向共享锁 IX意向排他锁 AI自增锁 Ⅱ.锁之间的兼容性 兼 X IX S IS X × × × × IX × ...

  3. DIOCP3-粘包处理

    DIOCP3-粘包处理   什么是粘包: 第一次发送  12345, 第二次发送abcde, 底层socket可能会一次性进行发送12345abcde,或者对方可能一次性进行了接收,那接收的时候,你可 ...

  4. day5_不能循环删除list-深拷贝、浅拷贝(import copy)

    一.循环删list里面的元素,会导致下标错位,结果是不对的举例:想删除奇数 l = [1,1,1,2,3,4,5] for i in l: if i%2 !=0: l.remove(i) #删除后,导 ...

  5. Kafka— —副本(均衡负载)

    创建一个副本数为3的topic Now create a new topic with a replication factor of three: > bin/kafka-topics.sh ...

  6. [svc]unix和cpu发展历史

    最近搞汇编 , 有一款8086cpu,16bit, 支持内存1M 于是勾起了对计算机历史的兴趣,多了解了下 unix起源历史 [Unix发展历史 - 程序猿-贝岩博客 - CSDN博客]https:/ ...

  7. 【Gradle】-NO.101.Gradle.1.gradle.1.001-【Gradle Configuration】-(

    Style:Gradle Series:Gradle Since:2018-09-20 End:2018-09-20 Total Hours:1 Degree Of Diffculty:5 Degre ...

  8. 11.c#类的成员初始化顺序

    转自http://www.cnblogs.com/siceblue/archive/2009/01/15/1376430.html C#作为一种纯面向对象的话言,为它编写的整个代码里面到处都离不开对象 ...

  9. ts中的类的定义,继承和修饰符

    自己搞一个ts文件 里面写代码如下,试一下就行了 /* 1.vscode配置自动编译 1.第一步 tsc --inti 生成tsconfig.json 改 "outDir": &q ...

  10. Linux文件系统的硬连接和软连接

    title: Linux文件系统的硬连接和软连接 date: 2018-02-06T20:26:25+08:00 tags: ["文件系统"] categories: [" ...