org.hibernate.exception.SQLGrammarException: could not fetch initial value for increment generator

以下是我的映射文件
Order.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->

<hibernate-mapping>  
    <class name="cn.itcast.hibernate0909.onetomany.test.Order" >  
        <id name="oid" type="integer">  
            <column name="id"></column>  
            <generator class="increment"></generator>  
        </id>  

        <property name="orderNumber" type="string" >  </property>  
        <property name="price" type="double"> </property>  

        <many-to-one name="customer" class="cn.itcast.hibernate0909.onetomany.test.Customer" >  
            <column name="customer_id" ></column>     
        </many-to-one>  
    </class>  
</hibernate-mapping>  

Customer.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->

<hibernate-mapping>  
<class name="cn.itcast.hibernate0909.onetomany.test.Customer" table="customers" >  
    <id name="cid" type="integer">  
        <column name="cid"></column>  
        <generator class="increment"></generator>  
    </id>  
    <property name="name" type="string" >  
    </property>  
</class>  
</hibernate-mapping>  

这里写图片描述

junit测试发现报错:
这里写图片描述

这里写图片描述

在这里的错误是使用了Mysql中的关键字’order’,再配置Order.hbm.xml文件时候,不设置表明,默认使用持久化类的类名order造成报错。
解决方法:设置表名
这里写图片描述
重新junit测试:
这里写图片描述

错误总结:
Hibernate: select max(‘主键名’) from ‘表名’
org.hibernate.exception.SQLGrammarException: could not fetch initial value for increment generator
解决方案:
1.查看一下表名是否与数据库中的表名相同,对于某些数据库,大小写是要区分的。
2.查看表名或者字段使用了数据库中的关键字

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值