sinat_28165519 2015-05-13 08:01 采纳率: 0%
浏览 3998

用hibernate在修改一条数据时没有覆盖旧的记录,反而添加了一条新纪录,怎么回事?

我用的是mysql的数据库,
jsp

<%@ page language="java" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags"%>

<!DOCTYPE HTML>





    <div class="form-group">
    <div class="col-sm-10">
    <center><h3>编辑部门信息</h3></center>
    </div>
    </div>



    <div class="form-group">
    <label for="dpname" class="col-sm-2 control-label">部门名称:</label>
    <div class="col-sm-6">
    <input name="department.dpname" type="text" class="form-control" id="dpname" value="${department.dpname}">
    </div>
    </div>

    <div class="form-group">
    <label for="dpnum" class="col-sm-2 control-label">部门人数:</label>
    <div class="col-sm-6">
    <input name="department.dpnum" type="number" class="form-control" id="dpnum" value="${department.dpnum}">
    </div>
    </div>

    <div class="form-group">
    <label for="dpmanager" class="col-sm-2 control-label">部门经理:</label>
    <div class="col-sm-6">
    <input name="department.dpmanager" type="text" value="${department.dpmanager}" class="form-control" id="dpmanager">
    </div>
    </div>


    <div class="form-group">
        <div class="col-sm-offset-2 col-sm-6">
            <button type="submit" class="btn btn-default">
            提交</button>
        </div>
    </div>
</form>

</div>
<script src="js/jquery-1.11.1.min.js" ></script>
<script src="js/bootstrap.min.js" ></script>


action

package com.admin.actions;
import hbn.Department;
import hbn.DepartmentDAO;

import java.util.List;

import org.hibernate.Transaction;
public class DeptAction {

        private Department department;
        private List dlist;
        private String dmessage;

        public Department getDepartment() {
            return department;
        }
        public void setDepartment(Department department) {
            this.department = department;
        }

        public List getDlist() {
            return dlist;
        }
        public void setDlist(List dlist) {
            this.dlist = dlist;
        }
        public String getDmessage() {
            return dmessage;
        }
        public void setDmessage(String dmessage) {
            this.dmessage = dmessage;
        }

        public String deptlist() {

            DepartmentDAO dd = new DepartmentDAO();
            Transaction tx = dd.getSession().beginTransaction();
            dlist = dd.findAll();
            tx.commit();
            dd.getSession().flush();
            String result = "deptlist";
            return result;
        }



        public String deptupdate() {
            String result;
            try {
                DepartmentDAO dd = new DepartmentDAO();
                department = dd.findById(department.getId());
                dd.getSession().beginTransaction().commit();
                result = "deptupdate";
            } catch (Exception e) {
                // TODO: handle exception
                dmessage = "无法编辑该部门信息!";
                result = "dmessage";
            }
            return result;
        }

        public String deptup() {
            String result;
            try {
                DepartmentDAO dd = new DepartmentDAO();
                Transaction tx = dd.getSession().beginTransaction();
                System.out.println(department);
                dd.merge(department);
                tx.commit();
                result = "success";
            } catch (Exception e) {
                // TODO: handle exception
                dmessage = "部门信息修改失败!";
                result = "error";
            }

            return result;
        }
}

求大家帮忙看看!

  • 写回答

3条回答 默认 最新

  • 离子光刀 2015-05-13 09:16
    关注

    你的dao层怎样写的?还有是不是传数据传少了 hibernate有个saveorupdate方法,当传入的对象带有主键时执行的是update操作,当传入的对象没用主键时执行的是insert操作,看你的描述 应该是传入的对象中没有带上主键

    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?