本文参考传智播客巴巴运动网
在后台修改订单的时候为了防止两个以上的工作人员同时修改订单,需要对订单进行锁定。
锁定的具体方法如下:
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就行了。