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" } })

  • 相关阅读:
    Nodejs的下载和安装以及环境配置
    java的JDK的安装和环境变量配置
    CSS3与页面布局——概要、选择器、特殊性与刻度单位
    angular2.x 多选框事件
    NiceFish的ERROR in AppModule is not an NgModule问题
    angularjs分页组件
    获取当前日期
    angularjs实现星星评分
    angularjs1 自定义轮播图(汉字导航)
    获取未来几天的日期以及是星期几
  • 原文地址:https://www.cnblogs.com/webenh/p/7919500.html
Copyright © 2011-2022 走看看