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的方式生成。
分享到:
相关推荐
碰到了 #1062 – Duplicate entry ‘1′ for key ‘PRIMARY’ 当时那个急啊,原本的数据我已经全部删除了,没办法只有请求万能的百度了。我找了大半天终于给我给我找到了。兴奋ing,马上测试,O(∩_∩)O哈哈~成功了...
[mysql]mysql通过on duplicate key update实现批量插入或更新(csdn)————程
今天公司的一个网站突然提示MySQL Error Duplicate entry '96624' for key 1错误,经过分析这个问题是由于mysql表中的一个id自增长字段导致。
主要介绍了MYSQL的REPLACE和ON DUPLICATE KEY UPDATE语句介绍解决问题实例,需要的朋友可以参考下
本文介绍一下关于mysql中INSERT INTO… ON DUPLICATE KEY UPDATE用法
MySQL里Create Index 能否创建主键 Primary Key? 答案: 不能,必须用 Alter table 创建。 MySQL一个索引列最大允许的有效长度,不是列的所有数据都被索引的MyISAM 是 1000字节 InnoDB 是 767 字节 注意这里是字节。...
总结,对于主键与唯一索引约束: • 执行insert和update时,会触发约束检查 • InnoDB违反约束时,会回滚对应SQL • MyISAM违反约束时,会中断对应的SQL,可能造成不符合预期的结果集 • 可以使用 insert … on ...
本篇文章是对mysql "ON DUPLICATE KEY UPDATE"语法进行了详细的分析介绍,需要的朋友参考下
MySQL中如何处理重复数据(Duplicate)?
例如,如果列a被定义为unique,并且值为1,则下列语句有同样的效果,也就是说... 另外值得一提的是,这个语句知识mysql中,而标准sql语句中是没有的。 INSERT INTO .. ON DUPLICATE KEY更新多行记录 如果在INSERT语句末
mysql “ON DUPLICATE KEY UPDATE” 语法如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则在出现重复值的行执行UPDATE;如果不会导致唯一值列...
Mysql进行数据备份,还原后进行回帖,出现以下错误代码,其实主要是导入数据重复的问题,将现在的数据表清空,重新导入即可
android studio创建9.patch图片,使用时出现Error: Duplicate resources 笔者运行环境:MacOs Catalina , android studio 3.6.3 原创文章 5获赞 2访问量 249 关注 私信 展开阅读全文 作者:徐州捕快
Fast Duplicate File Finder
文件查重工具Duplicate Cleaner Pro v4.0.5 安装后不急于打开程序,断网,拷贝X86和x64中的license文件,然后打开程序,注册码一栏任意输入文字即可,点击应用注册即可成功注册。
FirmTools Duplicate Photo Finder 相似图像查询软件 你电脑中如果有很多图像,有很多可能是一个logo只差,你用其他md5检测软件是不能快速找出来的。这个软件可以搜索相似的图像,你查看后选择删除,非常的方便。 ...
duplicate绝对干货。利用duplicate复制数据库,文档中包换每一步的试验步骤,详细说明了每一步的作用及用途,和注意事项,一步一步至试验成功,绝对一次成功。
今天听同事介绍oracle到mysql的数据migration,他用了Insert into ..... on duplicate key update ...,我当时就想怎么不用Replace呢,于是回来就仔细查了下,它们果然还是有区别的
mysql数据库Insert语句后加ONDUPLICATE KEY UPDATE,保证唯性如果在INSERT语句末尾指定了ON DUPLICATE KEY UP