Hibernate用SchemaExport自动创建不了表

来源:转载

我的环境: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查看,表成功创建。

分享给朋友:
您可能感兴趣的文章:
随机阅读: