MySQL复制表结构和数据的SQL语句

1. 复制表结构及数据到新表

   CREATE TABLE new_table SELECT * FROM old_table 


2. 只复制表结构到新表

       CREATE TABLE new_table SELECT * FROM old_table WHERE 1=2   


[color=red] 注意:只要让WHERE条件不成立 [/color]

3.复制旧表的数据到新表(假设两个表结构一样)

INSERT INTO new_table  SELECT * FROM old_table 


4.复制旧表的数据到新表(假设两个表结构不一样)
INSERT INTO new_table(字段1,字段2,…….) SELECT 字段1,字段2,…… FROM old_table 


5、CREATE TABLE 方法

整表复制 # create table 新表 select * from 旧表; 
结构复制 # create table 新表 select * from 旧表 where 1<>1;


6、INSERT INTO 方法

得到建表语句 # show create table 旧表; 
新建表

复制数据到新表 INSERT INTO new_table(col1,col2,...) (SELECT col1,col2,... FROM old_table);


以上是在同一个数据库中进行的操作,如果要在不同的数据库操作,记得加
上数据库名。


[b]例子:[/b]

数据库中,将某个表的数据插入另一个表中是比较常见的,以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
这点必须得注意
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值