Hibernate用SchemaExport自动创建不了表
2017-10-13 08:58
351 查看
我的环境:MySql5、Hibernate5.2.11Final。
首先,用SchemaExport自动创建表,Hibernate5.2.11Final的写法如下:
执行后hibernate自动生成如下SQL语句:
查看数据库,表却并没有创建,而且执行hibernate的crud会出现”could not execute statement“的错误,并提示没有查找到表。因此可以确定,在自动创建表的过程中出现问题。
于是把上面create table的sql语句放入navicat执行,报错提示错误出现在type=MyISAM附近。
上网一查,原来是sql版本问题,在sql4时可以写成type=MyISAM,但sql5变成了engine=MyISAM,因此猜测hibernate不知道我用的是sql5,于是更改cfg文件如下:
<
4000
p>将方言设置为MYSQL5,加一个5进去。hibernate就能自动生成基于sql5的sql语句,执行测试单元,重启navicat查看,表成功创建。
首先,用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>
<
4000
p>将方言设置为MYSQL5,加一个5进去。hibernate就能自动生成基于sql5的sql语句,执行测试单元,重启navicat查看,表成功创建。
相关文章推荐
- Hibernate之——使用SchemaExport类自动创建数据库表
- Hibernate和Mysql5.5创建表出错——type=InnDB/schema export unsuccessful
- Hibernate初学者---schemaExport自动生成联合主键关联数据表
- Hibernate和Mysql5.5创建表出错——type=InnDB/schema export unsuccessful
- Hibernate和MySQL5.5创建表出错--'type=InnoDB'/schema export unsucessful
- 利用ant,hibernate的schemaexport自动生成数据库
- [Hibernate系列—] 3. 映射文件与使用SchemaExport自动产生Schema
- 【Hibernate】——SchemaExport自动生成数据库表
- [Hibernate系列—] 3. 映射文件与使用SchemaExport自动产生Schema
- Hibernate 使用SchemaExport自动生成表
- 通过hibernate SchemaExport手动创建表结构
- Hibernate5.2.10使用SchemaExport创建数据库
- 使用hibernate的SchemaExport来创建数据库
- java hibernate SchemaExport 创建数据表
- hibernate使用SchemaExport自动生成数据表
- Hibernate自动创建表
- 一口一口吃掉Hibernate(一)——使用SchemaExport生成数据表
- Hibernate自动创建表
- Hibernate 自动根据映射创建数据库表
- Hibernate 5.x版本中SchemaExport的用法