如何将mysql数据库一个database中的所有表合并到一个新表中 20

下面是我的代码,里面DATABASE_TABLES是错的,TABLE_NAME不确定对不对,我想表达的意思是提取出一个database中表名前缀是pl_express_l... 下面是我的代码,里面DATABASE_TABLES是错的,TABLE_NAME不确定对不对,我想表达的意思是提取出一个database中表名前缀是pl_express_longbang_201403的所有表中所有表中的内容,合并到一个新表中,不知这个DATABASE_TABLES和TABLE_NAME该用什么mysql关键字替换,或者这条语句有哪些地方需要修改,感谢各位的帮忙。create table pl_express_longbang as select * from DATABASE_TABLES where TABLE_NAME LIKE 'pl_express_longbang_201403%';
请各位大神帮忙解决一下,最近正在研究用ETL工具进行数据迁移,我想第一步现将mysql数据表都合并到一个表,然后再迁移到oracle数据库中。
展开
 我来答
dongdng
推荐于2018-03-04 · TA获得超过8158个赞
知道大有可为答主
回答量:9168
采纳率:88%
帮助的人:2276万
展开全部
以MySQL数据库为例,通过SQL命令行将某个表的所有数据或指定字段的数据,导入到目标表中。此方法对于SQLServer数据库,也就是T-SQL来说,同样适用 。

类别一、 如果两张张表(导出表和目标表)的字段一致,并且希望插入全部数据,可以用这种方法:(此方法只适合导出两表在同一database)
INSERT INTO 目标表 SELECT * FROM 来源表;
例如,要将 articles 表插入到 newArticles 表中,则可以通过如下SQL语句实现:
INSERT INTO newArticles SELECT * FROM articles;

类别二、 如果只希望导入指定字段,可以用这种方法:
INSERT INTO 目标表 (字段1, 字段2, ...) SELECT 字段1, 字段2, ... FROM 来源表;
请注意以上两表的字段必须一致(字段类型),否则会出现数据转换错误。

1、跨服务器复制表中数据
insert into openrowset('sqloledb','localhost';'sa';'123',Test.dbo.Table_B)
select * from Test.dbo.Table_A
//启用Ad Hoc Distributed Queries:
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
//使用完成后,关闭Ad Hoc Distributed Queries:
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure

2、//不跨服务器
insert into dbo.Table_B) select * from dbo.Table_A
将表名和数据库连接字符串用代码拼接好 然后执行上述您需要的sql语句 程序功能即可完成

将一个mysql数据库中的一个表导入到另一个mysql数据库中

db1为原数据库,db2为要导出到的数据库,fromtable 是要导出的表名

1.方法一:
登录导出到的数据库,执行
create table fromtable select * from db1.fromtable;
2.方法二:
在cmd下执行,mysqldump -u root -p db1 fromtable file=d:/fromtable.sql; 输入秘密,root为用户名
登录db2 执行 source d:/fromtable.sql;
3.方法三:
登录db1 执行 select * from fromtable into outfile "d:/fromtable .txt"; 导出纯数据格式
登录db2 执行 load data infile d:/fromtable .txt into table fromtable; 需要先建一张和原表结构一样的空表。
4.建一个odbc连接,先导出到access中,再导出到另一个库中。
Ailiex
2014-06-26 · TA获得超过996个赞
知道小有建树答主
回答量:1108
采纳率:37%
帮助的人:548万
展开全部
你这样查是不行的,语法错的。
你需要先把类似表名查出来,然后再拼接SQL 语句,如

insert into tablea
select * from pl_1
union all
select * from pl_2
union all
select * from pl_n
更多追问追答
追问
你好,我这个类似表很多,有一千个,请问该怎么查询啊
追答
在SQL SERVER 上面我可以写出来,MYSQL不是很熟,
表名可以在系统表里找,select * from mysql.tables where name like '%aaa%',
取出来后,把表分批拼成INSERT语句。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2015-05-06
展开全部
首先你要确定这些表名之间有什么规律吗?
其次表的物理的结果是否相同啊
尝试用存储过程。达到合并的效果啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式