论坛首页 综合技术论坛

mysql 数据表复制-insert into select from

浏览 2884 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2011-03-02  

        数据库中,将某个表的数据插入另一个表中是比较常见的,以mysql为例

语法:

 customer2,customer3都只有2个字段,id,name

 1、指定具体的表字段

 INSERT INTO customer3(id,NAME)  SELECT id,NAME FROM customer2

 2、全部字段

 INSERT INTO customer3  SELECT * FROM customer2

 INSERT INTO customer3  SELECT id,NAME FROM customer2

 

注意:以下,我们把insert称为左操作,select称为右操作

1、插入的目标与源表的字段类型最好是相互匹配,否则可能会有警告或者精确度下降,更甚的插入不成功;另外左右操作的表字段数要相等;左操作数与又操作数的顺序,类型要兼容

2、如果在插入的目标表中不指定插入的字段,则表示插入所有字段。

3、左操作不指定插入字段时,其顺序是按照表中字段的顺序的,右操作按照生母的字段顺序给左操作的字段赋值;如果右操作也不指定字段,则按照表中字段的顺序排列。

比如 customer3 的字段声明顺序为  id,name

customer2 的字段声明顺序为  name,id,则 INSERT INTO customer3  SELECT * FROM customer2语句中,

customer3.id=customer2.name

customer3.name=customer2.id

这点必须得注意

论坛首页 综合技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics