我的环境:MySql5、Hibernate5.2.11Final。
首先,用SchemaExport自动创建表,Hibernate5.2.11Final的写法如下:
ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().configure().build();
Metadata metadata = new MetadataSources(serviceRegistry).buildMetadata();
SchemaExport schemaExport = new SchemaExport();
schemaExport.create(EnumSet.of(TargetType.DATABASE), metadata);
执行后hibernate自动生成如下SQL语句:
create table Score (
studID integer not null,
CourseID integer not null,
result float,
primary key (studID, CourseID)
) type=MyISAM
查看数据库,表却并没有创建,而且执行hibernate的crud会出现”could not execute statement“的错误,并提示没有查找到表。因此可以确定,在自动创建表的过程中出现问题。
于是把上面create table的sql语句放入navicat执行,报错提示错误出现在type=MyISAM附近。
上网一查,原来是sql版本问题,在sql4时可以写成type=MyISAM,但sql5变成了engine=MyISAM,因此猜测hibernate不知道我用的是sql5,于是更改cfg文件如下:
<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
将方言设置为MYSQL5,加一个5进去。hibernate就能自动生成基于sql5的sql语句,执行测试单元,重启navicat查看,表成功创建。