A数据库,B数据库
目的:将 A库 中的表 导入到 B库 中
注意:create table B.products as select * from A.products 与create table B.products like A.products 的区别
mysql下测试:
源表:A
表结构如下
mysql> show create table products \G
*************************** 1. row ***************************
Table: products
Create Table: CREATE TABLE `products` (
`products_id` int(11) NOT NULL AUTO_INCREMENT,
`language_id` int(11) NOT NULL DEFAULT '1',
`products_name` varchar(255) NOT NULL DEFAULT '',
`products_description` text,
`products_url` varchar(255) DEFAULT NULL,
`products_viewed` int(5) DEFAULT '0',
`itemno` varchar(100) DEFAULT NULL,
PRIMARY KEY (`products_id`,`language_id`),
FULLTEXT KEY `products_name` (`products_name`)
) ENGINE=MyISAM AUTO_INCREMENT=10740 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC
a 使用create as select语句创建表
mysql> create table B.products as select * from A.products;
mysql> show create table products \G
*************************** 1. row *******************
Table: products
Create Table: CREATE TABLE `products` (
`products_id` int(11) NOT NULL DEFAULT '0',
`language_id` int(11) NOT NULL DEFAULT '1',
`products_name` varchar(255) NOT NULL DEFAULT '',
`products_description` text,
`products_url` varchar(255) DEFAULT NULL,
`products_viewed` int(5) DEFAULT '0',
`itemno` varchar(100) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
对比源表的表结构,发现AUTO_INCREMENT、PRIMARY KEY (`products_id`,`language_id`)、FULLTEXT KEY `products_name` (`products_name`)没有被创建
b 使用like子句创建表
mysql> create table B.products like A.products;
mysql> show create table B.products \G
*************************** 1. row **********************
Table: products
Create Table: CREATE TABLE `products` (
`products_id` int(11) NOT NULL AUTO_INCREMENT,
`language_id` int(11) NOT NULL DEFAULT '1',
`products_name` varchar(255) NOT NULL DEFAULT '',
`products_description` text,
`products_url` varchar(255) DEFAULT NULL,
`products_viewed` int(5) DEFAULT '0',
`itemno` varchar(100) DEFAULT NULL,
PRIMARY KEY (`products_id`,`language_id`),
FULLTEXT KEY `products_name` (`products_name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC
1 row in set (0.00 sec)
将 A.products 表中的数据添加到 B.products
insert into B.products select * from A.products;
对比源表的表结构,两者完全一致,完整的包含了表结构和索引
结论:mysql下create table B.products as select * from A.products 形式创建的表不包含索引信息,like子句形式包含完整表结构和索引信息
所以 as select 子句一般适用于建表并复制源表数据的情况,like子句适用于只复制表结构的情况
误用的风险: 索引的缺失对于业务的性能是致命的
Oracle下:
a create as select同样不会创建索引
b oracle不支持like子句
至于如何实现完全创建表结构和索引的方法有待继续探讨!
(今天更换数据库时本人用的as,导致网站打不开,反应相当缓慢,特意整理一份,希望对大家有点帮助!)