如何向表中插入数据以及如何更新、删除表中的数据

简介: 1. 插入INSERT 用来将行插入到数据库表中。插入有几种方式:插入完整的行。插入行的一部分。插入某些查询的结果。INSERT 语法要求指定表名和插入到新表中的值。例如,我们将一个新顾客插入到 customers 表中。插入前:INSERT INTO Customers VALUES('1000000006', 'Toy Land', '123 Any Street', 'New York', 'NY', '11111', 'USA', 'Jordan', 'Jordan@gmail.com');运行结果如下:插入到新表中的值由 VALUES 子

1. 插入

INSERT 用来将行插入到数据库表中。插入有几种方式:

  • 插入完整的行。
  • 插入行的一部分。
  • 插入某些查询的结果。

INSERT 语法要求指定表名和插入到新表中的值。例如,我们将一个新顾客插入到 customers 表中。

插入前:

网络异常,图片无法展示
|

INSERT INTO Customers VALUES('1000000006', 'Toy Land', '123 Any Street', 
    'New York', 'NY', '11111', 'USA', 'Jordan', 'Jordan@gmail.com');

运行结果如下:

网络异常,图片无法展示
|

插入到新表中的值由 VALUES 子句给出,以这种方式插入数据时,我们必须为每一列提供一个值。而且各列必须以他们在表定义中出现的次序填充。虽然这种插入数据的语法很简单,但并不安全,应该尽量避免使用。因为上面的 SQL 语句高度依赖于表中列的定义次序。比较安全的写法,如下:

INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, 
    cust_state, cust_zip, cust_country, cust_contact, cust_email)
VALUES('1000000006', 'Toy Land', '123 Any Street', 'New York', 
    'NY', '11111', 'USA', 'Jordan', 'Jordan@gmail.com');

运行结果如下:

网络异常,图片无法展示
|

在上述写法中,我们在表名后的括号里明确指定了列名,VALUES 中的第一个值对应于第一个指定列名,第二个值对应于第二个列名,如此等等。因为提供了列名,只要 VALUES 中的值和指定的列名能匹配上就行,不一定按照各列出现在表中的实际次序。这样做的好处是,即使表结构发生改变,这条 INSERT 语句仍然能正确工作。由于明确指定了列名,所以我们可以随意指定列的顺序。

例如,我们也可以如下插入数据:

INSERT INTO Customers(cust_id, cust_contact, cust_email, cust_name, 
    cust_address, cust_city, cust_state, cust_zip, cust_country)
VALUES('1000000006', 'Jordan', 'Jordan@gmail.com', 'Toy Land', 
    '123 Any Street', 'New York', 'NY', '11111','USA');

运行结果如下:

网络异常,图片无法展示
|

注意事项:1.不要使用没有明确给出列的 INSERT 语句。给出列能使 SQL 代码继续发挥作用,即使表结构发生了变化。2.不管使用哪种 INSERT 语法,VALUES 的数目都必须正确。如果不提供列名,则必须给每个表列提供一个值;如果提供列名,则必须给列出的每个列一个值。否则,就会产生一条错误消息,相应的行不能成功插入。

由于明确列出了列名,我们在进行插入数据时,可以省略某些列,这表示可以只给某些列提供值,给其他列不提供值。例如,我们可以如下插入数据:

INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country)
VALUES('1000000006', 'Toy Land', '123 Any Street', 'New York', 'NY', '11111', 'USA');

运行结果如下:

网络异常,图片无法展示
|

在这个例子中,我们省略了 cust_contact 和 cust_email 这两列。如果表的定义允许,则可以在 INSERT 操作中省略某些列。省略的列必须满足以下某个条件:1.该列定义为允许 NULL 值。2.在表定义中给出默认值。这表示如果不给出值,将使用默认值。如果表中不允许有 NULL 值或者默认值,这时却省略了表中的值, DBMS 就会产生错误消息,相应的行不能成功插入。

INSERT 还可以用来将查询出的数据插入到表中。就是所谓的 INSERT SELECT。它由一条 INSERT 语句和一条 SELECT 语句组成。

例如,未进行操作前, customersnew 表中的内容是空的:

网络异常,图片无法展示
|

我们从 customers 表中查询数据插入到 customersnew 表中。

INSERT INTO customersnew(cust_id, 
                      cust_contact, 
                      cust_email, 
                      cust_name, 
                      cust_address, 
                      cust_city, 
                      cust_state, 
                      cust_zip, 
                      cust_country)
SELECT cust_id, 
       cust_contact, 
       cust_email, 
       cust_name, 
       cust_address, 
       cust_city, 
       cust_state, 
       cust_zip, 
       cust_country 
FROM customers;

运行结果如下:

网络异常,图片无法展示
|

可以发现已经执行完成。

然后我们打开 customersnew 表, 可以发现数据已经插入成功:

网络异常,图片无法展示
|

在这个例子中,INSERT 和 SELECT 语句中使用了相同的列名。但是,不一定要求列名匹配。事实上,DBMS 一点儿也不关心 SELECT 返回的列名。它使用的是列的位置,因此 SELECT 中的第一列(不管其列名)将用来填充表列中指定的第一列,第二列将用来填充表列中指定的第二列,如此等等。

INSERT SELECT 中 SELECT 语句可以包含 WHERE 子句,以过滤插入的数据。

另外,有时候,我们需要把一个表的内容复制到另外一张表。这时候我们可以使用:

CREATE TABLE custcopy AS 
SELECT * FROM customers;

运行结果如下:

网络异常,图片无法展示
|
网络异常,图片无法展示
|

可以发现sql语句的执行与表内容的复制都已完成,其内容与 customers 中的内容一致

2. 更新

下面我们来讲下如何更新数据:更新表中的数据可以使用 UPDATE 语句,有两种使用 UPDATE 的方式:1.更新表中的特定行。2.更新表中的所有行。

使用 UPDATE 语句非常容易,基本的 UPDATE 语句由三部分组成:1.要更新的表。2.列名和它们的新值。3.确定要更新哪些行的过滤条件。

举个简单的例子,例如我们要更新客户 1000000005 的电子邮箱地址,语句如下:

UPDATE customers 
SET cust_email = 'kim@thetoystore.com' 
WHERE cust_id = '1000000005';

执行结果如下:

网络异常,图片无法展示
|

UPDATE 语句以 WHERE 子句结束,它告诉 DBMS 更新哪一行。没有 WHERE 子句,DBMS 将会用这个电子邮件地址更新 Customers 表中的所有行, 这不是我们希望的。

更新多列的语法稍微不同,例如:

UPDATE Customers 
SET cust_contact = 'Sam Roberts',
    cust_email = 'sam@toyland.com' 
WHERE cust_id = '1000000006';

执行结果如下:

网络异常,图片无法展示
|

在更新多个列时,只需要使用一条 SET 命令,每个“列=值”对之间用逗号分隔(最后一列之后不用逗号)。在此例子中,更新顾客 1000000006 的 cust_contact 和 cust_email 列。

要删除某个列的值,可设置它为 NULL。例如:

UPDATE Customers 
SET cust_email = NULL 
WHERE cust_id = '1000000005';

执行结果如下:

网络异常,图片无法展示
|

在使用 UPDATE 语句时,不要省略 WHERE 子句,因为稍不注意,就会更新表中所有的行。

3. 删除

下面来讲下如何删除数据:从一个表中删除数据,使用 DELETE 语句。有两种使用 DELETE 的方式:1.从表中删除特定的行;2.从表中删除所有行。例如:从Customers 表中删除一行:

DELETE FROM Customers 
WHERE cust_id = '1000000006';

执行结果如下:

网络异常,图片无法展示
|

DELETE 不需要列名或通配符。DELETE 删除整行而不是删除列。要删除指定的列,请使用 UPDATE 语句。

如果想从表中删除所有行,不要使用 DELETE。可使用 TRUNCATE TABLE 语句,它完成相同的工作,而速度更快(因为不记录数据的变动)。

使用 UPDATE 和 DELETE 时所遵循的重要原则:1.除非确实打算更新和删除每一行,否则绝对不要使用不带 WHERE 子句的 UPDATE 或 DELETE 语句。2.在 UPDATE 或 DELETE 语句使用 WHERE 子句前,应该先用 SELECT 进行测试,保证它过滤的是正确的记录,以防编写的 WHERE 子句不正确。

1.更新客户 1000000001 的电子邮箱地址为 justin@gmail.com。

2.复制vendors表中内容,并命名为copy。

目录
相关文章
|
1月前
修改数据和删除数据
修改数据和删除数据。
17 1
|
1月前
|
存储 关系型数据库 MySQL
Mysql数据库清空表 truncate和delete
Mysql数据库清空表 truncate和delete
18 0
|
8月前
|
关系型数据库 MySQL 数据库
在MySQL数据库中插入、更新与删除数据
在MySQL数据库中插入、更新与删除数据。
63 2
|
5月前
|
SQL 存储 关系型数据库
③【操作表数据】MySQL添加数据、修改数据、删除数据
③【操作表数据】MySQL添加数据、修改数据、删除数据
37 0
|
8月前
数据更新语句INSERT语句、UPDATE语句、DELETE语句等,用于向数据表中插入、更新或删除数据。示例
数据更新语句INSERT语句、UPDATE语句、DELETE语句等,用于向数据表中插入、更新或删除数据。示例
55 1
|
11月前
|
关系型数据库 MySQL
|
11月前
|
SQL 关系型数据库 MySQL
|
SQL 数据库
DML 添加、修改、删除数据
DML英文全称是Data Manipulation Language(数据操作语言),用来对数据库中表的数据记录进行增、删、改操作。
175 0
|
SQL 存储 关系型数据库
MySQL数据库基本操作-DML——插入数据;删除数据;更新数据
MySQL数据库基本操作-DML——插入数据;删除数据;更新数据
248 0
MySQL数据库基本操作-DML——插入数据;删除数据;更新数据