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查看,表成功创建。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值