永发信息网

java后台如何向数据库同一张表同时插入多条数据,请看如下保存数据操作代码是否正确。

答案:2  悬赏:0  手机版
解决时间 2021-03-02 02:30
  • 提问者网友:欲劫无渡
  • 2021-03-01 19:55
// 查用户信息表,取yuid
String yhxxhql = "select yuid from Yonghuxinxi a where 1=1 ";
Session session = kaoqinDao.getSessionFactory().getCurrentSession();
Query query = session.createQuery(yhxxhql);
List listyh = query.list();
//查考勤班次表,取kqbcid
String bancihql = "select kqbcid from Kaoqinbanci k where 1=1";
Query query2 = session.createQuery(bancihql);
List listbc = query2.list();
//判断操作标识符
String opflag=kaoqinModel.getOpflag();
String kqid = kaoqinModel.getKqid();
Kaoqin kaoqin = null;
if (opflag.equals("add")) {
kaoqin = new Kaoqin();
} else if (opflag.equals("edit")) {
kaoqin = this.kaoqinDao.findById(kqid);
if (kaoqin == null ) {
throw new ClassNotFoundException("系统查无此用户");
}
kaoqinModel.setAdddate(kaoqin.getAdddate());// 编辑状态下,保留原来的adddate
}else{
throw new Exception("无此操作");
}
// 初始化日期
if (opflag.equals("add")) {
kaoqin.setAdddate(new Date());
kaoqin.setEditdate(new Date());
}else if (opflag.equals("edit")) {
// 编辑状态下,yonghu里面的adddate容易被model替换成null,注意
kaoqin.setEditdate(new Date());
}else{
throw new Exception("无此操作");
}
// 保存数据
if (opflag.equals("add")) {
if(listyh != null){
for(int i = 0;i if(listbc != null){
kaoqinModel.setKqbcid(listyh.get(i).toString());
for(int j = 0;j kaoqinModel.setYuid(listbc.get(j).toString()); BeanUtils.copyProperties(kaoqin, kaoqinModel);
ComObj.commonOperation("insert", this.kaoqinDao, kaoqin);
}

}
}
}
}else if (opflag.equals("edit")) {
// 先把中间表数据删掉,再重新插入
// Session session = kaoqinDao.getSessionFactory()
// .getCurrentSession();
// 去掉readonly限制,不要用AUTO属性,AUTO属性会插入主表后,才删除中间表信息,导致缺失中间表数据
session.setFlushMode(FlushMode.COMMIT);
Transaction trans = session.beginTransaction();
try {
session.saveOrUpdate(kaoqin);// 保存用户
session.flush();
trans.commit();
} catch (Exception e) {
trans.rollback();
e.printStackTrace();
throw new Exception("编辑失败" + e);

}

}else{
throw new Exception("无此操作");
}
最佳答案
  • 五星知识达人网友:山君与见山
  • 2021-03-01 20:02
准备INSERT的Object,每次都要new,就会insert多条记录
全部回答
  • 1楼网友:鱼芗
  • 2021-03-01 20:49
你好! batch commit 希望对你有所帮助,望采纳。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯