Java tutorial
/** * Copyright 2014 Comcast Cable Communications Management, LLC * * This file is part of CATS. * * CATS is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * CATS is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with CATS. If not, see <http://www.gnu.org/licenses/>. */ package com.comcast.cats.recorder.persistence; import java.io.File; import java.net.URL; import java.util.ArrayList; import java.util.List; import org.hibernate.cfg.AnnotationConfiguration; import org.hibernate.tool.hbm2ddl.SchemaExport; /** * A simple utility to create schema based on Entity classes. * */ public class SqlTableCreator { private AnnotationConfiguration cfg; public SqlTableCreator(String packageName) throws Exception { cfg = new AnnotationConfiguration(); cfg.setProperty("hibernate.hbm2ddl.auto", "create"); for (Class<Object> clazz : getClasses(packageName)) { cfg.addAnnotatedClass(clazz); } } /** * Method that actually creates the file. * * @param dbDialect * to use */ private void generate(Dialect dialect) { cfg.setProperty("hibernate.dialect", dialect.getDialectClass()); SchemaExport export = new SchemaExport(cfg); export.setDelimiter(";"); export.setOutputFile("ddl_" + dialect.name().toLowerCase() + ".sql"); export.execute(true, false, false, false); } /** * Utility method used to fetch Class list based on a package name. * * @param packageName * (should be the package containing your annotated beans. */ @SuppressWarnings("rawtypes") private List<Class> getClasses(String packageName) throws Exception { List<Class> classes = new ArrayList<Class>(); File directory = null; try { ClassLoader cld = Thread.currentThread().getContextClassLoader(); if (cld == null) { throw new ClassNotFoundException("Can't get class loader."); } String path = packageName.replace('.', '/'); URL resource = cld.getResource(path); if (resource == null) { throw new ClassNotFoundException("No resource for " + path); } directory = new File(resource.getFile()); } catch (NullPointerException x) { throw new ClassNotFoundException( packageName + "does not appear to be a valid package. " + x.getMessage()); } if (directory.exists()) { String[] files = directory.list(); for (int i = 0; i < files.length; i++) { if (files[i].endsWith(".class")) { // removes the .class extension classes.add(Class.forName(packageName + '.' + files[i].substring(0, files[i].length() - 6))); } } } else { throw new ClassNotFoundException(packageName + " is not a valid package"); } return classes; } /** * Holds the classnames of hibernate dialects for easy reference. */ private static enum Dialect { ORACLE("org.hibernate.dialect.Oracle10gDialect"), MYSQL("org.hibernate.dialect.MySQLDialect"), HSQL( "org.hibernate.dialect.HSQLDialect"); private String dialectClass; private Dialect(String dialectClass) { this.dialectClass = dialectClass; } public String getDialectClass() { return dialectClass; } } /** * @param args */ public static void main(String[] args) throws Exception { SqlTableCreator gen = new SqlTableCreator("com.comcast.cats.reorder.persistence.domain"); gen.generate(Dialect.MYSQL); gen.generate(Dialect.ORACLE); gen.generate(Dialect.HSQL); } }