我在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

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

  1. java异步处理_SpringBoot异步开发之异步请求,在高并发的情况下,提高性能

    何为异步请求 在Servlet 3.0之前,Servlet采用Thread-Per-Request的方式处理请求,即每一次Http请求都由某一个线程从头到尾负责处理.如果一个请求需要进行IO操作,比如 ...

  2. binlog数据库不写入binlog_mysql在不开启binlog的情况下导出数据库

    问题背景 上个DBA已经走了,一些mysql数据库连所在服务器的系统账户也没有,只有mysql 数据库的root账户和业务账户,准备导出数据迁移至新服务器,可是mysqldump命令却是必须开启bin ...

  3. java servlet项目源码下载_java网上商城项目源码(jsp.servlet+javabean+mysql+jdbc)

    [实例简介] 网上商城所有基本功能实现. 包含所有图片等资源 包含数据库创建脚步 开发环境 jdk1.7 myeclipse10 tomcat6.0 mysql 5 [实例截图] [核心代码] 325 ...

  4. java ftp遍历所有子文件_Java 遍历指定文件夹及子文件夹下的文件

    Java 遍历指定文件夹及子文件夹下的文件 /** * 遍历指定文件夹及子文件夹下的文件 * * @author testcs_dn * @date2014年12月12日下午2:33:49 * @pa ...

  5. java获得单元格的值_java – 从单元格值Apache POI获取单元格索引

    我想我明白你在追求的是什么 – 你想知道哪一列中包含"Patch"这个词的第一行?如果是这样,您需要做的就是: Sheet s = wb.getSheetAt(0); Row r ...

  6. JAVA实现在面板中添加图表_java-如何在不制作新图表的情况下将jzy3d图表添加到JFrame?...

    以下代码用于在JFrame中制作jzy3d图表: public class SurfaceViewerFrame extends IconFrame { public SurfaceViewerFra ...

  7. JAVA混合执行,Java8默认情况下是混合执行模式

    即解释型执行(JVM将class转换为底层机器码)和编译型执行(JIT,直接将源码转化为底层机器码),我们可以通过java的启动命令参数来选择的 List-1 mixed mode即混合模式 C:\U ...

  8. 怎样方便的在别人的PCB上修改,在你没有封装的情况下

    (1)生成PCB的封装库,其生成就可以,这样在同一个工程下,原理图自动拥有这个封装 (2)要是修改了原理图,这个原理图你自己库也没有其封装,所以需要添加一个你自己库也没有的封装,此时方便的做法是打开一 ...

  9. java mysql 文本导入数据语句_Java利用MYSQL LOAD DATA LOCAL INFILE实现大批量导入数据到MySQL...

    Mysql load data的使用 数据库中,最常见的写入数据方式是通过SQL INSERT来写入,另外就是通过备份文件恢复数据库,这种备份文件在MySQL中是SQL脚本,实际上执行的还是在批量IN ...

最新文章

  1. 大脑也在强化学习!加州大学提出「价值决策」被大脑高效编码,登Neuron顶刊...
  2. 打开适配器并捕获数据包
  3. 个性化推荐系统该如何评估,四种不同策略的角度
  4. jQuery入口函数的四种写法【1分钟掌握】
  5. [2020多校A层12.1]树(倍增/单调栈/dfs栈)
  6. LINQ学习中需要明确的几点问题
  7. NOIP模拟 color(DP)
  8. Oracle实战笔记(第二天)
  9. a链接易混淆与form表单简易验证用法详解
  10. 用Excel制作甘特图跟踪项目进度(附绘制教程)
  11. 计算机在线作业office,全国计算机一级office题库与答案
  12. 如何通过两步验证来保护您的Apple ID
  13. 处nm是什么意思_“nm”是什么意思啊?
  14. 《Flutter 控件大全》第十个:AnimatedIcon
  15. JVM学习之---了解JIT
  16. Java 近期新闻:Classfile API 草案、Spring Boot、GlassFish、Reactor 项目、Micronaut
  17. 安防 海康摄像机视频存储服务器
  18. 我辞职了!“没有Python编程经验的我,连简历都不敢投”
  19. 论文查重率太低了会怎么样?
  20. LCP插件linux-cp-xc-ip6节点

热门文章

  1. LeetCode算法题-Factorial Trailing Zeroes(Java实现)
  2. npm run dev 在本地调试出现跨域问题解决方法
  3. Scala学习:Curry化的函数
  4. Shell中的特殊字符
  5. CGContextAddLines和CGContextAddLineToPoint在线条半透明时候的区别
  6. 快速查询DB Lock的方法
  7. C#:委托基础与事件
  8. VI-ORB环境配置
  9. Robot Application Builder
  10. numpy——mgrid