zoukankan      html  css  js  c++  java
  • 后台修改,订单锁定

    在后台修改订单的时候为了防止两个以上的工作人员同时修改订单,需要对订单进行锁定。

    锁定的具体方法如下:

    View Code
    1 public Order getLockOrder(String orderid, String employee){
    2 em.createQuery("update Order o set o.employee=?1 where o.orderid=?2 and o.employee is null")
    3 .setParameter(1, employee).setParameter(2, orderid).executeUpdate();
    4 em.flush();//让数据库马上提交
    5 return this.find(orderid);
    6 }



     

     在订单表(Order)中,有一个Employee属性,我们只需要更新一下这个属性,就可以锁定订单,如果该属性不为null,则说明已经有人锁定了这个订单,我们不能更新该属性,只能等待该订单解锁以后再去更新。

     

    每当工作人员试图打开订单时都会进行如下操作:

     

    View Code
     1 /**
    2 * 订单信息查看
    3 */
    4 @Controller("/control/order/view")
    5 public class OrderViewAction extends Action {
    6 @Resource OrderService orderService;
    7
    8 @Override @Permission(model="order",privilegeValue="view")
    9 public ActionForward execute(ActionMapping mapping, ActionForm form,
    10 HttpServletRequest request, HttpServletResponse response)
    11 throws Exception {
    12 OrderForm formbean = (OrderForm) form;
    13 String username = WebUtil.getEmployee(request).getUsername();
    14 Order order = orderService.getLockOrder(formbean.getOrderid(), username);
    15 if(!order.getEmployee().equals(username)){
    16 request.setAttribute("message", "该订单已被"+ order.getEmployee() + "锁定");
    17 request.setAttribute("urladdress", SiteUrl.readUrl("control.order.list"));
    18 return mapping.findForward("message");
    19 }
    20 request.setAttribute("order", order);
    21 return mapping.findForward("order");
    22 }
    23
    24 }



     

    if语句判断如果Order的Employee和username相同的话则可以继续,否则显示订单已经被锁定。

     

    订单解锁的方法

    View Code
    1 public void unLock(String orderid){
    2 em.createQuery("update Order o set o.employee=?1 where o.orderid=?2")
    3 .setParameter(1, null).setParameter(2, orderid).executeUpdate();
    4 }

     只需要将对应的order的employee设置为null就行了。



  • 相关阅读:
    编码和解码总结
    编码和解码程序例
    IO流字节流输入输出格式
    递归经典题
    ArrayList去重
    集合
    接口文档
    Vue项目零碎知识(全局js,css配置,element-UI,bs使用, img动态配置,js数组)
    djang项目中的疑问及解决办法(ValueError: Invalid model reference 'apps.user.User'. String model references must be of the form 'app_label.ModelName'.)
    Django项目中出现的错误及解决办法(ValueError: Dependency on app with no migrations: customuser)
  • 原文地址:https://www.cnblogs.com/jerryxing/p/2436633.html
Copyright © 2011-2022 走看看