日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

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

發布時間:2023/12/10 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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

總結

以上是生活随笔為你收集整理的java怎么复制别人的数据库_java-如何在不使用Apache DDLUtils的情况下使用JDBC将模式从一个数据库复制到另一个数据库?...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美成人精品激情在线观看 | 黄色一级大片在线免费看产 | 国产美女精品在线 | a网站在线| 黑人玩弄人妻一区二区绿帽子 | 国产免费av一区二区 | 亚洲人天堂 | 在线免费观看不卡av | 青青草青娱乐 | 精品成人久久久 | 丁香美女社区 | 亚洲涩涩涩| 国产伊人自拍 | 天天干,天天爽 | 成人h动漫在线 | 日韩一区二区高清 | 天堂无乱码| 一区二区三区四区亚洲 | 久久一区国产 | 九九热8 | 99久久黄色 | 久久成人福利 | 三年中文在线观看免费观看 | 最新精品在线 | 久草福利在线观看 | 欧美激情伊人 | 97在线公开视频 | 中文字幕日本视频 | 蜜桃久久久 | 久久国产视频网站 | 日韩夜夜高潮夜夜爽无码 | 韩国伦理片在线看 | 伊人成人在线视频 | 五月天最新网址 | 99色综合网 | 亚洲日本视频在线观看 | 99热这| 九九在线精品视频 | 精东影业一区二区三区 | 成年人网站免费在线观看 | 日批黄色 | 99re视频在线 | 深夜福利视频网站 | 婷婷日| 99热自拍偷拍 | 欧美a级黄色片 | 亚州av网 | 69xav| 亚洲爱爱av | 西西毛片 | 国产乱偷| 久久精品网 | 日韩二级片 | 欧美亚洲在线播放 | 久久老熟女一区二区三区 | 全部免费毛片在线播放一个 | 日韩一区二区三区四区五区 | 伊人影院久久 | 亚洲AV成人无码网站天堂久久 | 精品麻豆一区二区 | 最新av网址在线观看 | 色666| 黄色男人的天堂 | 粉嫩aⅴ一区二区三区 | 久久天堂视频 | 97av在线 | 性高跟丝袜xxxxhd | 99热思思 | 中文字幕国产综合 | 肉色超薄丝袜脚交一区二区 | 欧美区国产区 | 713电影免费播放国语 | 亚洲jlzzjizz少妇 | 国产伦精品一区二区三区视频黑人 | 无码精品人妻一区二区 | 国产chinasex麻豆videos | 99免费观看视频 | 青青操免费 | 无码gogo大胆啪啪艺术 | 国产不卡av在线播放 | 日韩精品无码一区二区三区 | 亚洲欧美一区二区三区情侣bbw | 欧美成人69 | 亚洲图片中文字幕 | 久久久999成人 | 久久婷婷av | 刘玥91精选国产在线观看 | 欧美男人又粗又长又大 | 亚洲爽爽网 | 免费观看一级视频 | 日韩激情在线观看 | 福利资源导航 | 亚洲人成777| av资源免费观看 | 亚洲精品久久 | 欧美日韩精品网站 | 日韩福利电影在线 | 亚洲一区二区免费在线观看 | 欧美日本不卡 |