读书人

MySQL复构图结构和数据的SQL语句

发布时间: 2012-08-22 09:50:35 作者: rapoo

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

1. 复制表结构及数据到新表?
???????
?????Java代码??MySQL复构图结构和数据的SQL语句

  1. CREATE?TABLE?new_table?SELECT?*?FROM?old_table???
???????

2. 只复制表结构到新表?
???????
?Java代码??MySQL复构图结构和数据的SQL语句
  1. CREATE?TABLE?new_table?SELECT?*?FROM?old_table?WHERE?1=2?????


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

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

Java代码??MySQL复构图结构和数据的SQL语句
  1. INSERT?INTO?new_table??SELECT?*?FROM?old_table???


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


5、CREATE TABLE 方法?

Java代码??MySQL复构图结构和数据的SQL语句
  1. 整表复制?#?create?table?新表?select?*?from?旧表;???
  2. 结构复制?#?create?table?新表?select?*?from?旧表?where?1<>1;??


6、INSERT INTO 方法?

Java代码??MySQL复构图结构和数据的SQL语句
  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?
这点必须得注意?

读书人网 >Mysql

热点推荐