161121、hibernate导致数据出错的两个地方
一、在查询出来的对象上直接设置属性(该属性配置了可以持久化,如果不是可持久化的就没有关系)。
出错的代码:(查询用的不好也会导致数据更新哦)
Pagination pagination = groupJoinService.findByEg(groupJoin, true, cond, Pagination.cpn(pageNo),FrontUtils.pageSize(pageSize));//这是一个分页查询的方法使用hibernate的Criteria,最底下有代码
List<GroupJoin> list = (List<GroupJoin>) pagination.getList();
if(null != list && list.size()>0){
for(GroupJoin bean:list){
if(null == bean.getPersons()){
Integer curPersons = groupStartService.getCurPersons(bean.getStartId());
bean.setPersons(curPersons);//这时候数据库中的这个对象数据有可能会变
if(curPersons >= minPersonOne){
bean.setStatus(GroupJoin.STATUS_CAN);
}else{
bean.setStatus(GroupJoin.STATUS_NO);
}
}else{
bean.setStatus(GroupJoin.STATUS_YES);
}
}
}
pagination.setList(list);
正确的代码:
Pagination pagination = groupJoinService.findByEg(groupJoin, true, cond, Pagination.cpn(pageNo),FrontUtils.pageSize(pageSize));
List<GroupJoin> gjs = new ArrayList<GroupJoin>();//重新new一个对象
List<GroupJoin> list = (List<GroupJoin>) pagination.getList();
if(null != list && list.size()>0){
for(GroupJoin bean:list){
if(null == bean.getPersons()){
Integer curPersons = groupStartService.getCurPersons(bean.getStartId());
bean.setPersons(curPersons);
if(curPersons >= minPersonOne){
bean.setStatus(GroupJoin.STATUS_CAN);
}else{
bean.setStatus(GroupJoin.STATUS_NO);
}
}else{
bean.setStatus(GroupJoin.STATUS_YES);
}
gjs.add(bean);//然后添加进去
}
}
pagination.setList(gjs);
二、设置主键生成方式时自己设置的id会被忽略掉(数据库mysql,持久层框架mysql)
将主键的生成方式设置成了identity,导致了自己设置了id会被忽略,最终使用数据库的自增长主键。
下面是代码及错误的xxx.hbm.xml配置
java代码:(service层中)
@Override
public User initUser(String openId,String nickname,String headimgurl,String address,String sex,String access_token,String refresh_token
,String expires_in,String state) throws Exception {
User user = findByOpenid(openId);
boolean isSellerUrl = FrontUtils.isSellerUrl(state);
if(null == user){
user = new User();
user.setOpenId(openId);
user.setAddTime(new Date());
user.setStatus(Integer.valueOf(1));
user.setAccessToken(access_token);
user.setRefreshToken(refresh_token);
user = save(user);
initUserDetail(user.getId(), headimgurl, nickname, address, openId, sex);//如果主键生成方式设置成了identity,就算你设置了id也会被忽略掉,直接使用数据库中自增长的id
if(isSellerUrl){//如果是商家链接初始化商家
initSeller(user.getId());
}
}else{
if(isSellerUrl){
Seller seller = sellerService.findById(user.getId());
if(null == seller){
initSeller(user.getId());
}
}
}
return user;
}
Seller.hbm.xml(问题出现在这里)
//省略
<hibernate-mapping package="com.sellers.entity">
<class name="Seller" table="sl_seller" dynamic-update="true">
<meta attribute="sync-DAO">false</meta>
<cache usage="read-write"/>
<id name="id" type="integer" column="id" ><generator class="identity"/></id>
//省略
修复后:<id name="id" type="integer" column="id" ><generator class="assigned"/></id>
上面实例查询的代码:
public Pagination findByEg(T eg, boolean anyWhere, Condition[] conds,
int page, int pageSize, String... exclude) {
Order[] orderArr = null;
Condition[] condArr = null;
if (conds != null && conds.length > 0) {
List<Order> orderList = new ArrayList<Order>();
List<Condition> condList = new ArrayList<Condition>();
for (Condition c : conds) {
if (c instanceof OrderBy) {
orderList.add(((OrderBy) c).getOrder());
} else {
condList.add(c);
}
}
orderArr = new Order[orderList.size()];
condArr = new Condition[condList.size()];
orderArr = orderList.toArray(orderArr);
condArr = condList.toArray(condArr);
}
Criteria crit = getCritByEg(eg, anyWhere, condArr, exclude);
return findByCriteria(crit, page, pageSize, null, orderArr);
}
@SuppressWarnings("rawtypes")
protected Pagination findByCriteria(Criteria crit, int pageNo,
int pageSize, Projection projection, Order... orders) {
int totalCount = ((Number) crit.setProjection(Projections.rowCount()).uniqueResult()).intValue();
Pagination p = new Pagination(pageNo, pageSize, totalCount);
if (totalCount < 1) {
p.setList(new ArrayList());
return p;
}
crit.setProjection(projection);
if (projection == null) {
crit.setResultTransformer(Criteria.ROOT_ENTITY);
}
if (orders != null) {
for (Order order : orders) {
crit.addOrder(order);
}
}
crit.setFirstResult(p.getFirstResult());
crit.setMaxResults(p.getPageSize());
p.setList(crit.list());
return p;
}
161121、hibernate导致数据出错的两个地方的更多相关文章
- jmeter随笔(9)--有两种编码风格,导致数据乱码
问题:在一个网站,有两种编码风格,导致数据乱码 解决办法: 1.首先设置jmeter的配置文件 2.针对要求是utf-8格式的这样的请求,做单独的编码处理(beanshell处理) 3.运行,在htm ...
- Hibernate在PostgreSQL上执行sum函数导致数据失真的问题
有一段通过Hibernate从PostgreSQL上进行sum统计的简单代码,但统计结果却导致数据失真,不知原因何在,求指教! Java代码片段如下: public List<Object> ...
- Hibernate的数据查找,添加!
1.首先看一下测试数据库的物理模型 2.测试所需要的Hibernate的jar包 3.数据库的sql /*=============================================== ...
- Struts2中validate数据校验的两种常用方法
本文主要介绍Struts2中validate数据校验的两种方法及Struts2常用校验器. 1.Action中的validate()方法 Struts2提供了一个Validateable接口,这个接 ...
- 【Spark调优】大表join大表,少数key导致数据倾斜解决方案
[使用场景] 两个RDD进行join的时候,如果数据量都比较大,那么此时可以sample看下两个RDD中的key分布情况.如果出现数据倾斜,是因为其中某一个RDD中的少数几个key的数据量过大,而另一 ...
- hibernate实现数据实体复制保存
hibernate实现数据实体复制保存 2013年12月16日 11:57:22 Hardy008 阅读数:3474 描述:需要将数据的一条记录进行复制保存为一条新记录. 思路:从数据库中取得一条 ...
- pt-osc改表导致数据不一致案例分析
2016-06-10 李丹 dba流浪猫 我们平时除了解决自己问题外,有时候也会协助圈内人士,进行一些故障排查,此案例就是帮某公司DBA进行的故障分析,因为比较典型,特分享一下,但仅仅是分享发生的过程 ...
- Spark-5-如何定位导致数据倾斜的代码
数据倾斜只会发生在shuffle过程中.这里给大家罗列一些常用的并且可能会触发shuffle操作的算子:distinct.groupByKey.reduceByKey.aggregateByKey.j ...
- ubuntu server 12.04U盘安装,提示无法挂载安装光盘或光盘读取数据出错
今天用Ultraiso将Ubuntu server 12.04 刻入U盘中安装系统,中间提示错误:1.检测不到cdrom(即U盘没有挂载上):2.从光盘中读取数据出错.问题如下图所示: 上网搜了下解决 ...
随机推荐
- 苹果公司给出的检测 advertisingIdentifier 的方法
To locate the reference to the advertisingIdentifier selector, please perform these steps to create ...
- Android设计模式源码解析之外观模式(Facade)
https://github.com/simple-android-framework/android_design_patterns_analysis/tree/master/facade/elsd ...
- chart crash
* thread #155: tid = 0x1fcc10, 0x0000000107626745 gpxj`static gpxj.ChartUtils.decimals (gpxj.ChartUt ...
- App上架审核指南翻译
App Store Review Guidelines APP审核指南:https://developer.apple.com/app-store/review/guidelines/ 本文是自主翻译 ...
- tornado中使用Mako模版
tornado是一个优秀的python的开源web 框架,框架本身的性能确实很好,但是他自带的模版只能说是一般般.关于tornado的详细信息可以直接到管网参考. http://www.tornado ...
- composer很慢修改镜像
有两种方式启用本镜像服务: 系统全局配置: 即将配置信息添加到 Composer 的全局配置文件 config.json 中.见“例1” 单个项目配置: 将配置信息添加到某个项目的 composer. ...
- Swift实战-豆瓣电台(二)界面布局
观看地址 http://v.youku.com/v_show/id_XNzMwMDg4NzAw.html 这节的内容主要是storyboard的操作. 有以下几个知识点 1 TableView的Dat ...
- Lintcode: Minimum Subarray
Given an array of integers, find the subarray with smallest sum. Return the sum of the subarray. Hav ...
- ofbiz进击 第四节。 我的form之旅
一般使用ofbiz做后台管理的时候,多数会使用ofbiz的form去做后台.下面我就总结下我在使用form的时候的一些总结与问题吧. 1.首先,我们看如何使用最简单form去查询某个单个的对象,并对其 ...
- 对while((pid = waitpid(-1, &stat, WNOHANG)) > 0)不懂的地方,现在懂了
while((pid = waitpid(-1, &stat, WNOHANG)) > 0) 需要写到信号处理函数中,假如有10个子进程 只要父进程能够收到最后一个信号,就能把前面丢失的 ...