`
longgangbai
  • 浏览: 7349480 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Hibernate 中的SchemaUpdate工具源码分析使用

阅读更多

//导出数据库本对象的应用
package org.hibernate.tool.hbm2ddl;

import java.io.FileInputStream;
import java.io.FileWriter;
import java.io.Writer;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;

import org.hibernate.HibernateException;
import org.hibernate.JDBCException;
import org.hibernate.cfg.Configuration;
import org.hibernate.cfg.Environment;
import org.hibernate.cfg.NamingStrategy;
import org.hibernate.cfg.Settings;
import org.hibernate.dialect.Dialect;
import org.hibernate.jdbc.util.FormatStyle;
import org.hibernate.jdbc.util.Formatter;
import org.hibernate.jdbc.util.SQLStatementLogger;
import org.hibernate.util.PropertiesHelper;
import org.hibernate.util.ReflectHelper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * A commandline tool to update a database schema. May also be called from
 * inside an application.
 *
 * @author Christoph Sturm
 */
public class SchemaUpdate {

 private static final Logger log = LoggerFactory.getLogger( SchemaUpdate.class );
 private ConnectionHelper connectionHelper;
 private Configuration configuration;
 private Dialect dialect;
 private List exceptions;
 private boolean haltOnError = false;
 private boolean format = true;
 private String outputFile = null;
 private String delimiter;
 private Formatter formatter;
 private SQLStatementLogger sqlStatementLogger;

 public SchemaUpdate(Configuration cfg) throws HibernateException {
  this( cfg, cfg.getProperties() );
 }

 public SchemaUpdate(Configuration cfg, Properties connectionProperties) throws HibernateException {
  this.configuration = cfg;
  dialect = Dialect.getDialect( connectionProperties );
  Properties props = new Properties();
  props.putAll( dialect.getDefaultProperties() );
  props.putAll( connectionProperties );
  connectionHelper = new ManagedProviderConnectionHelper( props );
  exceptions = new ArrayList();
  formatter = ( PropertiesHelper.getBoolean( Environment.FORMAT_SQL, props ) ? FormatStyle.DDL : FormatStyle.NONE ).getFormatter();
 }

 public SchemaUpdate(Configuration cfg, Settings settings) throws HibernateException {
  this.configuration = cfg;
  dialect = settings.getDialect();
  connectionHelper = new SuppliedConnectionProviderConnectionHelper(
    settings.getConnectionProvider()
  );
  exceptions = new ArrayList();
  sqlStatementLogger = settings.getSqlStatementLogger();
  formatter = ( sqlStatementLogger.isFormatSql() ? FormatStyle.DDL : FormatStyle.NONE ).getFormatter();
 }

 public static void main(String[] args) {
  try {
   Configuration cfg = new Configuration();

   boolean script = true;
   // If true then execute db updates, otherwise just generate and display updates
   boolean doUpdate = true;
   String propFile = null;

   for ( int i = 0; i < args.length; i++ ) {
    if ( args[i].startsWith( "--" ) ) {
     if ( args[i].equals( "--quiet" ) ) {
      script = false;
     }
     else if ( args[i].startsWith( "--properties=" ) ) {
      propFile = args[i].substring( 13 );
     }
     else if ( args[i].startsWith( "--config=" ) ) {
      cfg.configure( args[i].substring( 9 ) );
     }
     else if ( args[i].startsWith( "--text" ) ) {
      doUpdate = false;
     }
     else if ( args[i].startsWith( "--naming=" ) ) {
      cfg.setNamingStrategy(
        ( NamingStrategy ) ReflectHelper.classForName( args[i].substring( 9 ) ).newInstance()
      );
     }
    }
    else {
     cfg.addFile( args[i] );
    }

   }

   if ( propFile != null ) {
    Properties props = new Properties();
    props.putAll( cfg.getProperties() );
    props.load( new FileInputStream( propFile ) );
    cfg.setProperties( props );
   }

   new SchemaUpdate( cfg ).execute( script, doUpdate );
  }
  catch ( Exception e ) {
   log.error( "Error running schema update", e );
   e.printStackTrace();
  }
 }

 /**
  * Execute the schema updates
  *
  * @param script print all DDL to the console
  */
 public void execute(boolean script, boolean doUpdate) {

  log.info( "Running hbm2ddl schema update" );

  Connection connection = null;
  Statement stmt = null;
  Writer outputFileWriter = null;

  exceptions.clear();

  try {

   DatabaseMetadata meta;
   try {
    log.info( "fetching database metadata" );
    connectionHelper.prepare( true );
    connection = connectionHelper.getConnection();
    meta = new DatabaseMetadata( connection, dialect );
    stmt = connection.createStatement();
   }
   catch ( SQLException sqle ) {
    exceptions.add( sqle );
    log.error( "could not get database metadata", sqle );
    throw sqle;
   }

   log.info( "updating schema" );

   
   if ( outputFile != null ) {
    log.info( "writing generated schema to file: " + outputFile );
    outputFileWriter = new FileWriter( outputFile );
   }
   
   String[] createSQL = configuration.generateSchemaUpdateScript( dialect, meta );
   for ( int j = 0; j < createSQL.length; j++ ) {

    final String sql = createSQL[j];
    String formatted = formatter.format( sql );
    try {
     if ( delimiter != null ) {
      formatted += delimiter;
     }
     if ( script ) {
      System.out.println( formatted );
     }
     if ( outputFile != null ) {
      outputFileWriter.write( formatted + "\n" );
     }
     if ( doUpdate ) {
      log.debug( sql );
      stmt.executeUpdate( formatted );
     }
    }
    catch ( SQLException e ) {
     if ( haltOnError ) {
      throw new JDBCException( "Error during DDL export", e );
     }
     exceptions.add( e );
     log.error( "Unsuccessful: " + sql );
     log.error( e.getMessage() );
    }
   }

   log.info( "schema update complete" );

  }
  catch ( Exception e ) {
   exceptions.add( e );
   log.error( "could not complete schema update", e );
  }
  finally {

   try {
    if ( stmt != null ) {
     stmt.close();
    }
    connectionHelper.release();
   }
   catch ( Exception e ) {
    exceptions.add( e );
    log.error( "Error closing connection", e );
   }
   try {
    if( outputFileWriter != null ) {
     outputFileWriter.close();
    }
   }
   catch(Exception e) {
    exceptions.add(e);
    log.error( "Error closing connection", e );
   }
  }
 }

 /**
  * Returns a List of all Exceptions which occured during the export.
  *
  * @return A List containig the Exceptions occured during the export
  */
 public List getExceptions() {
  return exceptions;
 }

 public void setHaltOnError(boolean haltOnError) {
  this.haltOnError = haltOnError;
 }

 public void setFormat(boolean format) {
  this.formatter = ( format ? FormatStyle.DDL : FormatStyle.NONE ).getFormatter();
 }

 public void setOutputFile(String outputFile) {
  this.outputFile = outputFile;
 }

 public void setDelimiter(String delimiter) {
  this.delimiter = delimiter;
 }

}

设置适当的方法实现相应的功能

 

测试代码

package org.hibernate.test.schemaupdate;

import junit.framework.Test;
import junit.framework.TestSuite;

import org.hibernate.cfg.Configuration;
import org.hibernate.junit.UnitTestCase;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.hibernate.tool.hbm2ddl.SchemaUpdate;

/**
 *  */
public class MigrationTest extends UnitTestCase {

 public MigrationTest(String str) {
  super( str );
 }

 public static Test suite() {
  return new TestSuite( MigrationTest.class );
 }

 public void testSimpleColumnAddition() {
  String resource1 = "org/hibernate/test/schemaupdate/1_Version.hbm.xml";
  String resource2 = "org/hibernate/test/schemaupdate/2_Version.hbm.xml";

  Configuration v1cfg = new Configuration();
  v1cfg.addResource( resource1 );
  new SchemaExport( v1cfg ).execute( false, true, true, false );

  SchemaUpdate v1schemaUpdate = new SchemaUpdate( v1cfg );
  v1schemaUpdate.execute( true, true );

  assertEquals( 0, v1schemaUpdate.getExceptions().size() );

  Configuration v2cfg = new Configuration();
  v2cfg.addResource( resource2 );

  SchemaUpdate v2schemaUpdate = new SchemaUpdate( v2cfg );
  v2schemaUpdate.execute( true, true );
  assertEquals( 0, v2schemaUpdate.getExceptions().size() );

 }

}

 

分享到:
评论

相关推荐

    Hibernate+中文文档

    目录 前言 1. 翻译说明 2. 版权声明 1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class ...20.4. SchemaUpdate命令行选项 20.5. SchemaValidator命令行参数

    hibernate-extensions和Middlegen-Hibernate

    其中,最具吸引力的是它的`SchemaExport`和`SchemaUpdate`工具,这两个工具能够根据配置的实体类自动生成数据库的DDL脚本,或者直接在现有的数据库上更新表结构。此外,hibernate-extensions还支持动态代理,允许...

    hibernate3.2中文文档(chm格式)

    HIBERNATE - 符合Java习惯的关系数据库持久化 Hibernate参考文档 3.2 -------------------------------------------------------------------------------- 目录 前言 1. 翻译说明 2. 版权声明 1. Hibernate...

    HibernateAPI中文版.chm

    HIBERNATE - 符合Java习惯的关系数据库持久化 Hibernate参考文档 3.2 -------------------------------------------------------------------------------- 目录 前言 1. 翻译说明 2. 版权声明 1. Hibernate...

    hibernate链接oracle

    在本篇文章中,我们将深入探讨如何使用Hibernate框架连接Oracle数据库,并通过具体的代码示例来理解整个过程。以下内容将详细解释配置文件中的每一部分及其作用,帮助读者更好地理解和掌握这一技术。 #### 配置数据...

    hibernate入门

    Hibernate提供了诸如SchemaExport、SchemaUpdate等工具,用于根据实体类自动生成数据库表结构,或者同步数据库结构,简化了数据库的维护工作。 10. **最佳实践** 使用Hibernate时,应注意不要滥用Session,避免...

    Hibernate_3.2.0_符合Java习惯的关系数据库持久化

    HIBERNATE - 符合Java习惯的关系数据库持久化 Hibernate参考文档 3.2 -------------------------------------------------------------------------------- 目录 前言 1. 翻译说明 2. 版权声明 1. Hibernate...

    hishop升级包

    `SchemaUpdate.sql`是升级过程中至关重要的一环。在Hishop6.1中,开发者可能对数据库架构进行了优化,例如增加新的字段以支持新功能,或者改进现有字段的数据类型以提高查询性能。在执行这个SQL脚本前,务必备份原有...

    易分销.2.0to2.0.1.Upgrade.易分销2.0升级包

    这个升级包的主要目的是为了让现有用户能够顺利地将他们的易分销系统升级到最新版本,以获取新版本中的功能改进和性能优化。 易分销系统是一款专门用于商品分销和管理的软件,它可能包含了订单处理、库存管理、分销...

Global site tag (gtag.js) - Google Analytics