java-如何在不使用Apache DDLUtils的情况下使用JDBC将模式从一个数据库复制到另一个数据库?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java-如何在不使用Apache DDLUtils的情况下使用JDBC将模式从一个数据库复制到另一个数据库?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3439字,纯文字阅读大概需要5分钟。
内容图文
![java-如何在不使用Apache DDLUtils的情况下使用JDBC将模式从一个数据库复制到另一个数据库?](/upload/InfoBanner/zyjiaocheng/888/685bf997a61f46e78116f8e599e5425a.jpg)
我在MySQL中有一个数据库,我想以编程方式在FileMaker Pro中创建所有相同的表和字段.我可以使用JDBC自己完成此操作,但我希望已经有了可以执行此操作的库.
我研究了来自Apache的DDLUtils,但无法弄清楚如何构建它(它在构建系统中使用Maven,尝试构建时会出现致命错误).
解决方法:
我自己编写了代码,但事实证明并没有那么难.这是为了生成MySQL模式.我尚未测试FileMaker,但应该非常相似.
package com.prosc.db;
import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashSet;
import java.util.Set;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* Created by IntelliJ IDEA. User: jesse Date: 11/21/11 Time: 1:34 PM
*/
public abstract class SchemaGenerator {
private static final Logger log = Logger.getLogger( SchemaGenerator.class.getName() );
public String createDatabaseSql( String databasename ) {
return "CREATE DATABASE " + databasename;
}
/** This should return the String required to create a new table
* @param tableName The name of the table in the source database. This is also used as the name of the table to generate.
* @param metaData A JDBC metadata object from the source database (where the schema is being created from, not where it's being written to)
* */
public String createTableSql( DatabaseMetaData metaData, String tableName ) throws SQLException {
ResultSet columnsMetadata = metaData.getColumns( null, null, tableName, null );
Set<String> pkNames = new HashSet<String>(3);
try {
ResultSet pkResultSet = metaData.getPrimaryKeys( null, null, tableName );
while( pkResultSet.next() ) {
pkNames.add( pkResultSet.getString( 4 ) );
}
} catch( Exception e ) {
log.log( Level.WARNING, "Could not determine primary keys; will need to be manually configured", e );
}
StringBuffer sql = new StringBuffer();
sql.append( "CREATE TABLE " + tableName + " (" );
String delim = "";
while( columnsMetadata.next() ) {
sql.append( delim );
delim = ", ";
String columnName = columnsMetadata.getString( 4 );
String sqlTypename = columnsMetadata.getString(6);
int typeCode = columnsMetadata.getInt( 5 );
String targetTypename = targetTypename( sqlTypename, typeCode );
if( targetTypename == null ) {
log.info( "Unknown typename for type code " + typeCode + "; SQL type name is " + sqlTypename );
continue;
}
int columnSize = columnsMetadata.getInt( 7 );
boolean nullsProhibited = "NO".equalsIgnoreCase( columnsMetadata.getString(18) );
int precision = columnsMetadata.getInt( 9 );
appendFieldCreationClause( sql, columnName, targetTypename, columnSize, precision, nullsProhibited, pkNames.contains( columnName ), metaData.getIdentifierQuoteString(), columnsMetadata );
}
sql.append( ")" );
return sql.toString();
}
public void appendFieldCreationClause( StringBuffer buffer, String columnName, String targetTypename, int columnSize, int precision, boolean nullsProhibited, boolean isPrimaryKey, String identifierQuoteString, ResultSet columnMetaData ) {
if( isPrimaryKey ) {
targetTypename = "INT";
precision = 0;
}
buffer.append( identifierQuoteString + columnName + identifierQuoteString + " " + targetTypename );
if( columnSize > 0 ) {
buffer.append( "(" + columnSize );
if( precision > 0 ) {
buffer.append( "," + precision );
}
buffer.append( ")" );
}
if( "id".equalsIgnoreCase( columnName ) ) {
buffer.append( " UNIQUE" );
}
if( nullsProhibited ) {
buffer.append( " NOT NULL" );
}
if( isPrimaryKey ) {
buffer.append( " AUTO_INCREMENT" );
buffer.append( " PRIMARY KEY" );
}
}
public String targetTypename( String sqlTypename, int typeCode ) {
return sqlTypename;
}
}
内容总结
以上是互联网集市为您收集整理的java-如何在不使用Apache DDLUtils的情况下使用JDBC将模式从一个数据库复制到另一个数据库?全部内容,希望文章能够帮你解决java-如何在不使用Apache DDLUtils的情况下使用JDBC将模式从一个数据库复制到另一个数据库?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。