【1】表结构复制
第一种方式
create table 表名 like [数据库.]表名;
-- 如果是同一个数据库下的表的复制,不需要添加[数据库.];
-- 不会复制数据;
示例如下:
-- 原表创建语句:
CREATE TABLE `tb_lesson` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(60) DEFAULT NULL,
`joinTime` datetime DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=34 DEFAULT CHARSET=utf8;
-- 删除原表:
drop table tb_lesson;
--并从备份数据库复制
create table tb_lesson like db_exam2.tb_lesson;
-- 查看复制的新表语句;
CREATE TABLE `tb_lesson` (
`ID` int(11) NOT NULL AUTO_INCREMENT,
`Name` varchar(60) DEFAULT NULL,
`JoinTime` datetime DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- 字段属性未变
第二种方式
create table new_table
as
select * from [数据库名.]old_table;
-- 第二种方式在mysql下可能会丢失列属性,如主键,自增等。
示例如下:
-- 第二种方式复制的新表如下:
CREATE TABLE `tb_lesson` (
`ID` int(11) NOT NULL DEFAULT '0',
`Name` varchar(60) DEFAULT NULL,
`JoinTime` datetime DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- 改变了字段属性等。
-- 同时复制了数据;
-- 如果侧重表结构不建议使用这种方式。
【2】表数据复制
又被称为蠕虫复制,语法格式如下:
insert into Table2(field1,field2,...) select value1,value2,... from Table1;
// 如果不指定列,则如下(一定保证两个表列一致):
insert into new_table select * from [数据库.]old_table
指定列字段实例:
insert into tb_sys_news (category_name,category_id,user_name,user_id,content,field9,create_time)
select 'XX特色',1,'XXXXX',2,content,website,publish_time from sheetj1
需要注意的是,下面方式不适用于MySQL:
SELECT vale1, value2 into Table2 from Table1
该方式常常用于MySQL触发器、存储过程或函数中为变量赋值。
【3】不同数据库之间表复制
两个数据库之间表复制过程如下:
复制db_exam2数据库的表tb_lesson到当前数据库的表tb_lesson(表不出存在时需要创建)。
-- 删除已经存在的表;
drop table if EXISTS tb_lesson;
--复制并创建新表
create table tb_lesson like db_exam2.tb_lesson;
-- 复制数据
insert into tb_lesson select * from db_exam2.tb_lesson;
这里是从另外一个数据库(两个数据库在同一个主机)复制表和数据到当前数据库,省略了当前数据库名字。
也可以不省略数据库名字如下:
从data_analysis复制表和数据到data_analysis_zh。此处不管当前连接对象是哪个数据库,都可以正确执行。
drop table if EXISTS data_analysis_zh.store_card_2;
create table data_analysis_zh.store_card_2 like data_analysis.pos_sale;
INSERT into data_analysis_zh.store_card_2
select * from data_analysis.pos_sale where data_analysis.pos_sale.number_store_card >0;
select * from data_analysis_zh.store_card_2 ;
效果等同如下(打开data_analysis连接):
drop table if EXISTS data_analysis_zh.store_card_2;
create table data_analysis_zh.store_card_2 like pos_sale;
INSERT into data_analysis_zh.store_card_2
select * from pos_sale where number_store_card >0;
select * from data_analysis_zh.store_card_2 ;
效果等同如下(打开data_analysis_zh连接):
drop table if EXISTS store_card_2;
create table store_card_2 like data_analysis.pos_sale;
INSERT into store_card_2
select * from data_analysis.pos_sale where [data_analysis.pos_sale.]number_store_card >0;
select * from store_card_2 ;
参考博文:MySQL - 数据备份与还原(导出导入)。