本文参考传智播客巴巴运动网
在后台修改订单的时候为了防止两个以上的工作人员同时修改订单,需要对订单进行锁定。
锁定的具体方法如下:
public Order getLockOrder(String orderid, String employee){ em.createQuery("update Order o set o.employee=?1 where o.orderid=?2 and o.employee is null") .setParameter(1, employee).setParameter(2, orderid).executeUpdate(); em.flush();//让数据库马上提交 return this.find(orderid); }
在订单表(Order)中,有一个Employee属性,我们只需要更新一下这个属性,就可以锁定订单,如果该属性不为null,则说明已经有人锁定了这个订单,我们不能更新该属性,只能等待该订单解锁以后再去更新。
每当工作人员试图打开订单时都会进行如下操作:
/** * 订单信息查看 */ @Controller("/control/order/view") public class OrderViewAction extends Action { @Resource OrderService orderService; @Override @Permission(model="order",privilegeValue="view") public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { OrderForm formbean = (OrderForm) form; String username = WebUtil.getEmployee(request).getUsername(); Order order = orderService.getLockOrder(formbean.getOrderid(), username); if(!order.getEmployee().equals(username)){ request.setAttribute("message", "该订单已被"+ order.getEmployee() + "锁定"); request.setAttribute("urladdress", SiteUrl.readUrl("control.order.list")); return mapping.findForward("message"); } request.setAttribute("order", order); return mapping.findForward("order"); } }
if语句判断如果Order的Employee和username相同的话则可以继续,否则显示订单已经被锁定。
订单解锁的方法:
public void unLock(String orderid){ em.createQuery("update Order o set o.employee=?1 where o.orderid=?2") .setParameter(1, null).setParameter(2, orderid).executeUpdate(); }
只需要将对应的order的employee设置为null就行了。