Java导出MySQL数据库

8月份之前一直用的是oracle10g,有时候会用到plsqldeveloper开发工具。
之后就开始用MySQL数据了,标准的sql语法是一样的,但各个提供商会对标准进行扩展。

刚开始不知道有MySQL Front工具,就自己写java代码,导出数据库服务器中的几个数据库。
完成了导出表结构的时候,发现了Front工具和几个好用的MySQL语法,可能许多同仁根本没那么做过,分享一下。
先用工具导了出来,周末休息的时候,还是把java代码实现了,就是基于JDBC的,这里就不贴出来了,毕竟是新手,目前少于500行,写的很粗糙,还有要完善的地方,如配置多个数据库,对大表的分次导出,使用连接池。
就说说代码的心得吧:
>>show tables; 能返回一个数据库中的所有表名,使用ResultSet可以得到这些表名;
>>desc table_name; 能返回表中各个字段及属性,使用ResultSet。
>>如果不用desc table_name; 可以使用ResultSet的getMetaData()方法获取字段信息;
>>show create table table_name; 能返回表的DDL语句,同样使用ResultSet;
这里比desc table_name然后拼接表的DDL好多了,而且拼接的时候在外键处理上显得很麻烦。
>>最后使用上述的表名和字段名,以及SELECT出的数据,生成DML语句;

这样就可以把一个数据库中所有的表的DDL和DML语句写进sql文件,然后可以把这个文件当成脚本使用^..^。
一个数据库中如果有N个表的话,要访问DB 次数是2N+1次:1次show tables; N次show create table table_name;
N次select * from table_name; 写进文件的时候也很耗资源,可以做个定时任务于后半夜执行。

不知道导出工具是怎么做的?或者是DB记录了所有的DDL和DML,所以导出的速度较快;亦或是别的语言写的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值