zoukankan      html  css  js  c++  java
  • EF 数据版本号,处理具体使用方法 RowVersion / Timestamp 使用方法。进行自动处理并发修改

            /*
             * <div class="form-group">          // 原始
             * <div class="form-group hidden">   // 修改后
             * 
             * 
             *  原始:  @Html.EditorFor(model => model.RowVersion, new { htmlAttributes = new { @class = "form-control" } })
             *  修改后:@Html.HiddenFor(model => model.RowVersion, new { htmlAttributes = new { @class = "form-control" } })
             */

    生成的页面,进行替换操作。同样适用于 Timestamp

            /// <summary>
            /// 数据行版本号
            /// </summary>
            [Display(Name ="数据行版本号")]
            [Timestamp]
            public byte[] RowVersion { get; set; }

            /// <summary>
            /// 数据行版本号
            /// </summary>
            [Display(Name ="数据行版本号")]
            [Timestamp]
            public byte[] Timestamp { get; set; }

    如果发生异常,表示版本不一至。

    如:

            #region 修改数据时,如果行版本不一至,则报错,内容为:数据版本不一至,请返回重新进入再修改!
            private static readonly Exception _DbUpdateConcurrencyException = new Exception("数据版本不一至,请返回重新进入再修改!");
            /// <summary>
            /// 修改数据时,如果行版本不一至,则报错,内容为:数据版本不一至,请返回重新进入再修改!
            /// </summary>
            public static Exception DbUpdateConcurrencyException { get { return _DbUpdateConcurrencyException; } }
    
            private static readonly Exception _OptimisticConcurrencyException = new Exception("未设置行版本!");
            /// <summary>
            /// 未设置行版本!当更新操作违反并发约束时,就会引发此异常。
            /// </summary>
            public static Exception OptimisticConcurrencyException { get { return _OptimisticConcurrencyException; } }
            #endregion
    
    
    
            public override async Task<int> SaveChangesAsync()
            {
                try
                {
                    int result = await base.SaveChangesAsync();
                    return result;
                }
                catch (DbUpdateConcurrencyException)
                {
                    throw RowVersionHelper.DbUpdateConcurrencyException;
                }
                catch (OptimisticConcurrencyException)
                {
                    throw RowVersionHelper.OptimisticConcurrencyException;
                }
            }

     可以处理这个异常,进行自定义处理以给用户弹出友好提示。

    <div class="form-group">          // 原始
    <div class="form-group hidden">   // 修改后
    原始:  @Html.EditorFor(model => model.RowVersion, new { htmlAttributes = new { @class = "form-control" } })
    修改后:@Html.HiddenFor(model => model.RowVersion, new { htmlAttributes = new { @class = "form-control" } })

  • 相关阅读:
    DELPHI加密字串(异或运算加密)
    delphi 浮点数float转换成十六进制字符串的方法(FloatToHex)
    delphi 浮点数转换成十六进制字符串的方法
    LRC CRC 纵向冗余码校验
    lrc 校验码 ascii 格式
    LRC的效验码的计算方法
    写给嵌入式程序员的循环冗余校验(CRC)算法入门引导
    CRC的校验原理
    CRC校验
    RTU模式与ASCII模式有什么不同
  • 原文地址:https://www.cnblogs.com/webenh/p/7919500.html
Copyright © 2011-2022 走看看