打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
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<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;    }}
来源:https://www.icode9.com/content-2-497401.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
28个Java常用的工具类
Spring +Mybatis +oracle 实现数据库分页
MyBatis3.2 使用Interceptor进行分页
如何给 Log4j 配上数据库连接池
JAVA读取WORD,EXCEL,PDF,TXT,RTF,HTML文件文本内容的方法
StringBuilder in Javascript - Fengzhimei@Dot....
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服