MySQL INSERT INTO SELECT语句

时间:2019-11-20 08:52:07  来源:igfitidea点击:

简介:在本教程中,您将学习如何使用MySQL INSERT INTO SELECT语句将数据插入表中,其中数据来自SELECT语句的结果。

MySQL INSERT INTO SELECT概述

在上一教程中,您学习了如何使用INSERT语句以及在VALUES子句中指定的列值列表将一个或多个行插入表中。

INSERT INTO table_name(c1,c2,...)
VALUES(v1,v2,..);

除了在VALUES子句中使用行值外,还可以将SELECT语句的结果用作INSERT语句的数据源。

下面说明了INSERT INTO SELECT语句的语法:

INSERT INTO table_name(column_list)
SELECT 
   select_list 
FROM 
   another_table
WHERE
   condition;

在此语法中,可以使用SELECT语句来代替使用VALUES子句。
SELECT语句可以从一个或多个表中检索数据。

当您要将数据从其他表复制到一个表或将多个表中的数据汇总到一个表中时,INSERT INTO SELECT语句非常有用。

MySQL INSERT INTO SELECT示例

首先,创建一个名为suppliers的新表:

CREATE TABLE suppliers (
    supplierNumber INT AUTO_INCREMENT,
    supplierName VARCHAR(50) NOT NULL,
    phone VARCHAR(50),
    addressLine1 VARCHAR(50),
    addressLine2 VARCHAR(50),
    city VARCHAR(50),
    state VARCHAR(50),
    postalCode VARCHAR(50),
    country VARCHAR(50),
    customerNumber INT,
    PRIMARY KEY (supplierNumber)
);

请注意,您将在后续教程中学习如何创建新表。
目前,您只需要执行此语句即可创建供应商表。

假设来自美国加利福尼亚的所有客户成为公司的供应商。
以下查询查找位于美国加利福尼亚州的所有客户:

SELECT 
    customerNumber,
    customerName,
    phone,
    addressLine1,
    addressLine2,
    city,
    state,
    postalCode,
    country
FROM
    customers
WHERE
    country = 'USA' AND 
    state = 'CA';

其次,使用INSERT INTO ... SELECT语句将客户表中位于美国加利福尼亚的客户插入到供应商表中:

INSERT INTO suppliers (
    supplierName, 
    phone, 
    addressLine1,
    addressLine2,
    city,
    state,
    postalCode,
    country,
    customerNumber
)
SELECT 
    customerName,
    phone,
    addressLine1,
    addressLine2,
    city,
    state ,
    postalCode,
    country,
    customerNumber
FROM 
    customers
WHERE 
    country = 'USA' AND 
    state = 'CA';

它返回以下消息,指示已成功插入11行。

11 row(s) affected Records: 11  Duplicates: 0  Warnings: 0

第三,通过查询供应商表中的数据来验证插入内容:

SELECT * FROM suppliers;

这是输出:

在VALUES列表中使用SELECT语句

首先,创建一个名为stats的新表:

CREATE TABLE stats (
    totalProduct INT,
    totalCustomer INT,
    totalOrder INT
);

其次,使用INSERT语句插入来自SELECT语句的值:

INSERT INTO stats(totalProduct, totalCustomer, totalOrder)
VALUES(
	(SELECT COUNT(*) FROM products),
	(SELECT COUNT(*) FROM customers),
	(SELECT COUNT(*) FROM orders)
);

在此示例中:

  • 首先,将SELECT语句与COUNT()函数一起使用以获取总产品,员工和订单。

  • 第二,使用从SELECT语句返回的值代替INSERT语句的VALUES子句中的值。

第三,从tablestats查询数据:

SELECT * FROM stats;

在本教程中,您学习了如何使用MySQL INSERT INTO SELECT语句从结果集中将数据插入表中。