hibernate3.1
mysql5.1.16
映射文件 配置主键生成策略
<id name="userid" column="userid" type="int">
<generator class="increment"/>
</id>
保存数据的时候有时候会报 主键重复的异常
userid现在的值是399
报的异常是
SQL Error: 1062, SQLState: 23000
10:02:15 ERROR JDBCExceptionReporter - Duplicate entry '321' for key 1
10:02:15 ERROR AbstractFlushingEventListener - Could not synchronize database state with session
org.hibernate.exception.ConstraintViolationException: Could not execute JDBC batch update
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:71)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:253)
at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:266)
at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:167)
at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:298)
at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:27)
at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1000)
at org.springframework.orm.hibernate3.HibernateAccessor.flushIfNecessary(HibernateAccessor.java:390)
at org.springframework.orm.hibernate3.HibernateTemplate.doExecute(HibernateTemplate.java:420)
at org.springframework.orm.hibernate3.HibernateTemplate.executeWithNativeSession(HibernateTemplate.java:374)
at org.springframework.orm.hibernate3.HibernateTemplate.save(HibernateTemplate.java:694)
是什么问题呢,想了我一个晚上,没想到是哪里的问题
难道是native的问题?
数据库的问题?
程序的问题?
increment 适用于代理主键。由Hibernate自动以递增方式生成
identity 适用于代理主键。由底层数据库生成标识符
sequence 适用于代理主键。Hibernate根据底层数据库的序列生成标识符,这要求底层数据库支持序列
hilo 适用于代理主键。Hibernate分局high/low算法生成标识符
seqhilo 适用于代理主键。使用一个高/低位算法来高效的生成long,short或者int类型的标识符。
native 适用于代理主键。根据底层数据库对自动生成标识符的方式,自动选择identity、sequence或hilo
uuid.hex 适用于代理主键。Hibernate采用128位的UUID算法生成标识符
uuid.string 适用于代理主键。UUID被编码成一个16字符长的字符串
assigned 适用于自然主键。由Java应用程序负责生成标识符
foreign 适用于代理主键。使用另外一个相关联的对象的标识符
刚才看了一下日志 报错的对象都是这样的设置<generator class="increment" />
根据hibernate手册的描述,increment是由hibernate来完成自增长的,
increment主键生成器的org.hibernate.id.IncrementGenerator是使用select max( columnName ) from tableName的方式来获取,做应用负载出现问题是必然的。
所以应该杜绝increment的使用。
主键建议使用UUID的方式生成。
分享到:
相关推荐
MySQL中的自增长键是一种特殊类型的字段,主要用于主键,它能自动递增其数值,无需在插入新记录时显式指定。自增长键对于数据库管理非常有用,因为它简化了插入操作,尤其是当需要唯一标识符时。理解自增长键的工作...
但是,如果在达到这个值后尝试插入新数据,MySQL不会自动递增,而是报错`Duplicate entry '4294967295' for key 'PRIMARY'`。 3. **主键定义**: - 每个表应该有一个主键,它确保了表中记录的唯一性。如果在创建表...
同时,要留意不同数据库系统(如MySQL、SQL Server、Oracle)中主键自动增长的差异,以及在修改主键类型或处理主键重复时可能出现的问题。 总的来说,处理插入过程中主键和唯一键重复值的关键在于选择合适的方法来...
这个特性在处理像MySQL、SQL Server等支持自动增长字段的数据库时特别有用,可以避免进行额外的查询来获取新插入记录的主键。本文将深入探讨`useGeneratedKeys`的工作原理以及它在批量插入和`ON DUPLICATE KEY ...
当插入数据时,如果不提供自增长字段的值,MySQL会自动分配下一个可用的数值。 3. **唯一约束(Unique)** `unique`约束确保特定列的值在表中是唯一的,但可以有多个NULL值。例如: ```sql create table user3...
这里定义了一个名为`content`的表,包含7列:`content_id`(主键,自动增长)、`subject`、`words`、`username`、`face`、`email`和`createtime`。`NOT NULL`约束确保该列的值不能为空,`AUTO_INCREMENT`表示数值会...