`
fred2005
  • 浏览: 27174 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
最近访客 更多访客>>
社区版块
存档分类
最新评论

mysql自增长的主键Duplicate错误

阅读更多

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中的自增长键是一种特殊类型的字段,主要用于主键,它能自动递增其数值,无需在插入新记录时显式指定。自增长键对于数据库管理非常有用,因为它简化了插入操作,尤其是当需要唯一标识符时。理解自增长键的工作...

    MySQL的自增ID(主键) 用完了的解决方法

    但是,如果在达到这个值后尝试插入新数据,MySQL不会自动递增,而是报错`Duplicate entry '4294967295' for key 'PRIMARY'`。 3. **主键定义**: - 每个表应该有一个主键,它确保了表中记录的唯一性。如果在创建表...

    MySQL 处理插入过程中的主键唯一键重复值的解决方法

    同时,要留意不同数据库系统(如MySQL、SQL Server、Oracle)中主键自动增长的差异,以及在修改主键类型或处理主键重复时可能出现的问题。 总的来说,处理插入过程中主键和唯一键重复值的关键在于选择合适的方法来...

    Mybatis使用useGeneratedKeys获取自增主键的方法

    这个特性在处理像MySQL、SQL Server等支持自动增长字段的数据库时特别有用,可以避免进行额外的查询来获取新插入记录的主键。本文将深入探讨`useGeneratedKeys`的工作原理以及它在批量插入和`ON DUPLICATE KEY ...

    MySQL学习笔记之数据定义表约束,分页方法总结

    当插入数据时,如果不提供自增长字段的值,MySQL会自动分配下一个可用的数值。 3. **唯一约束(Unique)** `unique`约束确保特定列的值在表中是唯一的,但可以有多个NULL值。例如: ```sql create table user3...

    SQL语言的使用-数据库和表.doc

    这里定义了一个名为`content`的表,包含7列:`content_id`(主键,自动增长)、`subject`、`words`、`username`、`face`、`email`和`createtime`。`NOT NULL`约束确保该列的值不能为空,`AUTO_INCREMENT`表示数值会...

Global site tag (gtag.js) - Google Analytics