如何正確地在 MySQL 中使用 INSERT INTO … SELECT 來避免錯誤 1064?
首先,讓我們建立一個表格 -
mysql> create table DemoTable1 -> ( -> Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, -> FirstName varchar(100) -> ); Query OK, 0 rows affected (0.57 sec)
使用插入命令在表格中插入一些記錄 -
mysql> insert into DemoTable1(FirstName) values('John'); Query OK, 1 row affected (0.18 sec) mysql> insert into DemoTable1(FirstName) values('Chris'); Query OK, 1 row affected (0.13 sec)
使用 select 語句顯示來自表格的所有記錄 -
mysql> select *from DemoTable1;
以下會生成此輸出 -
+----+-----------+ | Id | FirstName | +----+-----------+ | 1 | John | | 2 | Chris | +----+-----------+ 2 rows in set (0.00 sec)
現在,建立一個第二張表 -
mysql> create table DemoTable2 -> ( -> CustomerId int, -> CustomerName varchar(100) -> ); Query OK, 0 rows affected (0.43 sec)
現在,可以使用 INSERT INTO SELECT 命令在上述表中插入一些記錄 -
mysql> insert into DemoTable2(CustomerId,CustomerName) -> select Id,FirstName from DemoTable1; Query OK, 2 rows affected (0.17 sec) Records: 2 Duplicates: 0 Warnings: 0
使用 select 語句顯示來自表格的所有記錄 -
mysql> select *from DemoTable2;
以下會生成此輸出 -
+------------+--------------+ | CustomerId | CustomerName | +------------+--------------+ | 1 | John | | 2 | Chris | +------------+--------------+ 2 rows in set (0.00 sec)
廣告