info.jtrac.hibernate.SchemaHelper.java Source code

Java tutorial

Introduction

Here is the source code for info.jtrac.hibernate.SchemaHelper.java

Source

/*
 * Copyright 2002-2005 the original author or authors.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package info.jtrac.hibernate;

import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaUpdate;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.StringUtils;

/**
 * <p>
 * Utilities to create the database schema, drop and create tables by using
 * the Hibernate schema tools.
 * </p>
 * <p>
 * This method is normally called at the first start of the application to
 * initialize the database.
 * </p>
 */
public class SchemaHelper {
    /**
     * Logger object
     */
    private final Logger logger = LoggerFactory.getLogger(getClass());

    /**
     * DB driver class name
     */
    private String driverClassName;

    /**
     * DB url
     */
    private String url;

    /**
     * DB user
     */
    private String username;

    /**
     * DB password
     */
    private String password;

    /**
     * DB hibernate dialect
     */
    private String hibernateDialect;

    /**
     * DB JNDI data source name
     */
    private String dataSourceJndiName;

    /**
     * Mapping information
     */
    private String[] mappingResources;

    /**
     * This method allows to store the name of the DB driver class.
     * 
     * @param driverClassName The name of the DB driver class.
     */
    public void setDriverClassName(String driverClassName) {
        this.driverClassName = driverClassName;
    }

    /**
     * This method allows to store the Hibernate dialect required for the
     * specified database. You can find the list of supported dialects in the
     * Hibernate documentation.
     * 
     * @param hibernateDialect The dialect name supported by Hibernate.
     */
    public void setHibernateDialect(String hibernateDialect) {
        this.hibernateDialect = hibernateDialect;
    }

    /**
     * This method allows to store multiple mapping resources.
     * 
     * @param mappingResources The String array of mapping Resources.
     */
    public void setMappingResources(String[] mappingResources) {
        this.mappingResources = mappingResources;
    }

    /**
     * This method allows to store the DB url.
     * 
     * @param url The DB url.
     */
    public void setUrl(String url) {
        this.url = url;
    }

    /**
     * This method allows to store the DB user.
     * 
     * @param username The DB user.
     */
    public void setUsername(String username) {
        this.username = username;
    }

    /**
     * This method allows to store the DB password.
     * 
     * @param password The DB password.
     */
    public void setPassword(String password) {
        this.password = password;
    }

    /**
     * This method allows to store the JNDI data source name.
     * 
     * @param dataSourceJndiName The JNDI data source name.
     */
    public void setDataSourceJndiName(String dataSourceJndiName) {
        this.dataSourceJndiName = dataSourceJndiName;
    }

    /**
     * Create tables using the given Hibernate configuration data.
     */
    public void createSchema() {
        Configuration cfg = new Configuration();

        if (StringUtils.hasText(dataSourceJndiName)) {
            cfg.setProperty("hibernate.connection.datasource", dataSourceJndiName);
        } else {
            cfg.setProperty("hibernate.connection.driver_class", driverClassName);
            cfg.setProperty("hibernate.connection.url", url);
            cfg.setProperty("hibernate.connection.username", username);
            cfg.setProperty("hibernate.connection.password", password);
        } // end if..else

        cfg.setProperty("hibernate.dialect", hibernateDialect);

        for (String resource : mappingResources) {
            cfg.addResource(resource);
        } // end for

        logger.info("begin database schema creation =========================");
        new SchemaUpdate(cfg).execute(true, true);
        logger.info("end database schema creation ===========================");
    }
}