`
ywChen
  • 浏览: 118608 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

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

阅读更多

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

Java代码  收藏代码
  1. CREATE TABLE new_table SELECT * FROM old_table   
       

2. 只复制表结构到新表 
       
 
Java代码  收藏代码
  1. CREATE TABLE new_table SELECT * FROM old_table WHERE 1=2     


  注意:只要让WHERE条件不成立 

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

Java代码  收藏代码
  1. INSERT INTO new_table  SELECT * FROM old_table   


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


5、CREATE TABLE 方法 

Java代码  收藏代码
  1. 整表复制 # create table 新表 select * from 旧表;   
  2. 结构复制 # create table 新表 select * from 旧表 where 1<>1;  


6、INSERT INTO 方法 

Java代码  收藏代码
  1. 得到建表语句 # show create table 旧表;   
  2. 新建表   
  3.   
  4. 复制数据到新表 INSERT INTO new_table(col1,col2,...) (SELECT col1,col2,... FROM old_table);   


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


例子: 

数据库中,将某个表的数据插入另一个表中是比较常见的,以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