MySQL复制表的三种方式(小结)
复制表结构及其数据
下面这个语句会拷贝数据到新表中。
注意:这个语句其实只是把select语句的结果建一个表,所以新表不会有主键,索引。
create table table_name_new as (select * from table_name_old);
只复制表结构
create table table_name_new as select * from table_name_old where 1=2;
或者
create table table_name_new like table_name_old;
注意:前一种方式是不会复制主键类型,索引的,而后一种方式是把旧表的所有字段类型都复制到新表。
只复制表数据
如果两个表结构一样
insert into table_name_new select * from table_name_old;
如果两个表结构不一样
insert into table_name_new(column1,column2...) select column1,column2... from table_name_old;
注意:很多文章说可以通过如下语句进行数据复制,table_name_new表可以不存在,会在执行的过程中自动创建。其实该SELECT ... INTO形式是使查询结果存储在变量或将其写入文件,即table_name_new是一个变量或者文件。
select column1,column2,.... into table_name_new from table_name_old;
到此这篇关于MySQL复制表的三种方式(小结)的文章就介绍到这了,更多相关MySQL 复制表内容请搜索好吧啦网以前的文章或继续浏览下面的相关文章希望大家以后多多支持好吧啦网!
相关文章:
1. 关于MyBatis10种超好用的写法(收藏)2. oracle中all、any函数用法与区别说明3. ORACLE常用傻瓜問題1000問(之十二)4. 讲解IBM DB2数据库性能调整的相关命令5. Hibernate 与 Mybatis 的共存问题,打破你的认知!(两个ORM框架)6. MySQL数据库中数值字段类型长度int(11)和Decimal(M,D)详解7. Django mysqlclient安装和使用详解8. 解决 Can’t connect to local mysql server through socket ‘/tmp/mysql.sock’ (2) |#20029. Oracle存储过程的几种调用方式图文详解10. 破解Oracle中国高层频繁变动之谜

网公网安备