import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
public class TestHibernate {
public static void main(String[] args) {
Configuration cfg = new AnnotationConfiguration();
SessionFactory sf = cfg.configure().buildSessionFactory();
Session session = sf.getCurrentSession();
session.beginTransaction();
new SchemaExport(new AnnotationConfiguration().configure()).create(true, true);
session.getTransaction().commit();
sf.close();
}
}
使用该方法可以在后台打印出创建表的语句,却无法在数据库中创建表。
查询hibernate.cfn.xml中的:
<property name="hbm2ddl.auto">create</property>
<property name="hbm2ddl.auto">update</property>
依旧无法解决。
原因:
方言问题,在mysql5.0后需要使用:
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
这样就可以创建了。