zoukankan      html  css  js  c++  java
  • 已实现乐观锁功能,FreeSql.DbContext 准备起航

    上回说到 FreeSql.DbContext 的规则,以及演示它的执行过程,可惜当时还不支持“乐观锁”,对于更新数据来讲并不安全。

    FreeSql 核心库 v0.3.27 已提供乐观锁支持。

    实现原理

    乐观锁的原理,是利用实体某字段,如:long version,更新前先查询数据,此时 version 为 1,更新时产生的 SQL 会附加 where version = 1,当修改失败时(即 Affrows == 0)抛出异常。

    每个实体只支持一个乐观锁,在属性前标记特性:[Column(IsVersion = true)] 即可。

    无论是使用 FreeSql/FreeSql.Repository/FreeSql.DbContext,每次更新 version 的值都会增加 1

    至此,FreeSql.DbContext 的更新操作就安全了。

    安装

    dotnet add package FreeSql.DbContext

    测试功能

    下面演示更新 BigNumber 属性,为什么定义他为 string 呢,对于数字的更新 set clicks = clicks + 1,是安全的操作。

    BigInteger 了解吗,我们就当 BigNumber 是一个超大的数字吧,普通数字无法表示的。

    var fsql = new FreeSql.FreeSqlBuilder()
        .UseConnectionString(FreeSql.DataType.Sqlite, @"Data Source=|DataDirectory|document.db;Pooling=true;Max Pool Size=10")
        .UseAutoSyncStructure(true)
        .UseLazyLoading(true)
        .UseNoneCommandParameter(true)
    
        .UseMonitorCommand(cmd => Trace.WriteLine(cmd.CommandText))
        .Build();
    
    public class Song {
        [Column(IsIdentity = true)]
        public int Id { get; set; }
        public string BigNumber { get; set; }
    
        [Column(IsVersion = true)]//使用简单
        public long versionRow { get; set; }
    }
    
    public class SongContext : DbContext {
    
        public DbSet<Song> Songs { get; set; }
    
        protected override void OnConfiguring(DbContextOptionsBuilder builder) {
            builder.UseFreeSql(fsql);
        }
    }
    

    当更新时,版本不正确提示以下错误,DbContext 将回滚操作:

    总结

    FreeSql.DbContext 实现类似 EFCore 使用方法,跟踪对象状态,最终通过 SaveChanges 方法提交事务。

    目前是第二个初版,已实现状态跟踪保存(导航属性的跟踪暂时不支持)。

    配合乐观锁这个杀手锏,FreeSql 越来越有 ORM 的影子了。

    github: https://github.com/2881099/FreeSql(求星星,谢谢)

  • 相关阅读:
    DevOps
    DevOps
    微信的NATIVE支付提示201商户订单号重复的解决方案
    phpstorm 破解
    Git忽略已经被版本控制的文件(添加.gitignore不会起作用)
    微信 {"errcode":48001,"errmsg":"api unauthorized, hints: [ req_id: 1QoCla0699ns81 ]"}
    如何用AJax提交name[]数组?
    基于PHP给大家讲解防刷票的一些技巧
    为何GET只发一次TCP连接,POST发两次TCP连接
    IP地址在mysql的存储(IP地址和int的转换)
  • 原文地址:https://www.cnblogs.com/kellynic/p/10624656.html
Copyright © 2011-2022 走看看