java怎么复制别人的数据库_java-如何在不使用Apache DDLUtils的情况下使用JDBC将模式从一个数据库复制到另一个数据库?...

我在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 pkNames = new HashSet(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;

}

}

来源:https://www.icode9.com/content-2-497401.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值