初识Hibernate:Could not instantiate id generator [entity-name=com.hibernate.e

本文分享了一次解决Hibernate框架中主键生成策略配置错误的经历,详细介绍了如何定位并修复问题,包括检查XML配置文件中的拼写错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近刚刚学 Hibernate 然后就遇到了错误,抓破了脑壳都不知道为什么,第二天又看了一遍代码,原来是我写错了单词

       <id name="deptNo" type="java.lang.Byte">
            <column name="deptno"/>
            <generator class="assigned"/>  //这个地方要注意,别写错
        </id>


org.hibernate.MappingException: Could not instantiate id generator [entity-name=com.xxx.xxx.xxx.Dept]     at org.hibernate.id.factory.DefaultIdentifierGeneratorFactory.createIdentifierGenerator(DefaultIdentifierGeneratorFactory.java:118)     at org.hi


源代码如下:

hibernate.cfg.xml-------------------------------------------------------------

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>e.entity.Dept" table="dept" schema
	<class name="com.xxx.hibernat="SCOTT">
		<id name="deptNo" type="java.lang.Byte">
			<column name="deptno"/>
			<!-- 
				主键生成策略:
					increment:自动增
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
	<session-factory>
		<!-- 1 数据库的连接字符串 -->
		<property name="connection.url">jdbc:oracle:thin:@127.0.0.1:1521:orcl</property>
		<!-- 2 登陆数据库的用户名 -->
		<property name="connection.username">scott</property>
		<!-- 3 登陆数据库的密码 -->
		<property name="connection.password">scott</property>
		<!-- 4 连接数据库的驱动类 -->
		<property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
		<!-- 5 数据库方言 -->
		<property name="dialect">org.hibernate.dialect.OracleDialect</property>
		<!-- 6  运行的时候显示sql语句-->
		<property name="show_sql">true</property>
		<!-- 7 格式化sql语句-->
		<property name="format_sql">true</property>
		<!-- 8 和当前线程绑定在一起 -->
		<property name="current_session_context_class">thread</property>
		
		<!-- 注册映射文件 -->
	<!-- /hiberate-chap1/src/com/xxx/hibernate/entity/Dept.hbm.xml -->
		<mapping resource="com/xxx/hibernate/entity/Dept.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

长;assigned:程序提供;native:由程序自己判断是程序提供主键值还是由数据库生成主键identity:使用数据的自动增长;
如mysql的auto_increment,sqlserver的identity(标识列)sequence:使用序列;如Oracle,比如Oracle数据库有有一个名为:seq_dept的序列,
那么在此处配置为:<generator class="sequence"><param name="sequence">seq_dept</param></generator> --><generator class="assigned"/></id>

<!-- property元素中的name属性值是实体类中的属性名称,type的属性值指的是实体类中对应属性的数据类型,column的属性值指的是数据库中表对应的列名 -->
<property name="deptName" type="java.lang.String" column="dname"/>
<property name="location" type="java.lang.String"><column name="loc"/>
</property></class></hibernate-mapping>


Dept.hbm.xml-------------------------------------------------------------------------------------

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<class name="com.XXX.hibernate.entity.Dept" table="dept" schema="SCOTT">
		<id name="deptNo" type="java.lang.Byte">
			<column name="deptno"/>
			<!-- 
				主键生成策略:
					increment:自动增长;
					assigned:程序提供;
					native:由程序自己判断是程序提供主键值还是由数据库生成主键
					identity:使用数据的自动增长;如mysql的auto_increment,sqlserver的identity(标识列)
					sequence:使用序列;如Oracle,比如Oracle数据库有有一个名为:seq_dept的序列,那么在此处配置为:
					<generator class="sequence">
						<param name="sequence">seq_dept</param>
					</generator>
			 -->
			<generator class="assigned"/>
		</id>
		<!-- 
			property元素中的name属性值是实体类中的属性名称,
			type的属性值指的是实体类中对应属性的数据类型,
			column的属性值指的是数据库中表对应的列名
		 -->
		<property name="deptName" type="java.lang.String" column="dname"/>
		<property name="location" type="java.lang.String">
			<column name="loc"/>
		</property>
	</class>
</hibernate-mapping>

原创作品:转摘请注明出处

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值