MySQL下使用SQL命令进行表结构与数据复制实践

【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 - 数据备份与还原(导出导入)

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

流烟默

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值