SmartSql 3.0.0-rc91

SmartSql = MyBatis + Cache(Memory | Redis) + ZooKeeper + R/W Splitting + ......

This is a prerelease version of SmartSql.
There is a newer version of this package available.
See the version list below for details.
Install-Package SmartSql -Version 3.0.0-rc91
dotnet add package SmartSql --version 3.0.0-rc91
<PackageReference Include="SmartSql" Version="3.0.0-rc91" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SmartSql --version 3.0.0-rc91
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

简介

SmartSql-Starter

0. Why

  • 拥抱 跨平台 DotNet Core,是时候了。
  • 把你的双手从数据访问层解放出来,少加点班吧。

1. So SmartSql

  • TargetFrameworks: .NETFramework 4.6 & .NETStandard 2.0
  • SmartSql = MyBatis + Cache(Memory | Redis) + ZooKeeper + R/W Splitting + ......

2. 主要特性 (√ 为已完成,未打 √ 为计划特性)

  • 1 ORM
    • 1.1 Sync
    • 1.2 Async
  • 2 XmlConfig & XmlStatement -> Sql
    • 2.1 SmartSqlMapConfig & SmartSqlMap √ (是的,你猜对了,和MyBatis一样,通过XML配置分离SQL。)
    • 2.2 Config Hot Update ->ConfigWatcher & Reload (配置文件热更新:当你需要修改Sql的时候,直接修改SqlMap配置文件,保存即可。)
  • 3 读写分离 √
    • 3.1 读写分离 √
    • 3.2 多读库 权重筛选 √ (配置多读库,根据读库权重选举读库)
  • 4 日志 √
    • 4.1 基于 Microsoft.Extensions.Logging.Abstractions (当你需要跟踪调试的时候一切都是那么一目了然)
  • 5 Dynamic Repository
    • 5.1 SmartSql.DyRepository √
  • 6 查询缓存 √
    • 6.1 SmartSql.Cache.Memory √
      • 6.1.1 Fifo √
      • 6.1.2 Lru √
    • 6.2 SmartSql.Cache.Redis √
    • 6.3 缓存事务一致性
  • 7 分布式配置插件
    • 7.1 IConfigLoader √ (配置文件加载器)
    • 7.2 LocalFileConfigLoader √ √ (本地文件配置加载器)
      • 7.2.1 Load SmartSqlMapSource Xml √
      • 7.3.1 Load SmartSqlMapSource Directory √
    • 7.3 SmartSql.ZooKeeperConfig √ (ZooKeeper 分布式配置文件加载器)

3. 性能


BenchmarkDotNet=v0.10.14, OS=Windows 10.0.16299.431 (1709/FallCreatorsUpdate/Redstone3)
Intel Core i7-4710MQ CPU 2.50GHz (Haswell), 1 CPU, 8 logical and 4 physical cores
Frequency=2435768 Hz, Resolution=410.5481 ns, Timer=TSC
.NET Core SDK=2.1.201
  [Host]     : .NET Core 2.0.7 (CoreCLR 4.6.26328.01, CoreFX 4.6.26403.03), 64bit RyuJIT
  DefaultJob : .NET Core 2.0.7 (CoreCLR 4.6.26328.01, CoreFX 4.6.26403.03), 64bit RyuJIT

| ORM | Type | Method | Mean | Error | StdDev | Rank | Gen 0 | Gen 1 | Gen 2 | Allocated |
|--------------- |------------------------- |------------------------ |---------:|----------:|----------:|-----:|-----------:|----------:|----------:|----------:|
| SmartSql | SmartSqlBenchmarks | Query | 101.6 ms | 0.2226 ms | 0.1738 ms | 1 | 2437.5000 | 1062.5000 | 375.0000 | 13.37 MB |
| Native | NativeBenchmarks | Query_IsDBNull_GetValue | 101.7 ms | 0.4101 ms | 0.3635 ms | 1 | 2437.5000 | 1062.5000 | 375.0000 | 13.37 MB |
| Dapper | DapperBenchmarks | Query | 104.4 ms | 1.3195 ms | 1.2342 ms | 2 | 3375.0000 | 1375.0000 | 625.0000 | 17.64 MB |
| SmartSqlDapper | SmartSqlDapperBenchmarks | Query | 105.7 ms | 1.1697 ms | 1.0941 ms | 3 | 3750.0000 | 1437.5000 | 625.0000 | 19.47 MB |
| Native | NativeBenchmarks | Query_GetValue_DbNull | 107.4 ms | 1.0710 ms | 1.0018 ms | 4 | 3062.5000 | 1187.5000 | 500.0000 | 16.42 MB |
| SqlSugar | SqlSugarBenchmarks | Query | 108.9 ms | 0.4048 ms | 0.3787 ms | 5 | 2375.0000 | 1000.0000 | 312.5000 | 13.09 MB |
| EF | EFBenchmarks | SqlQuery | 110.9 ms | 0.6922 ms | 0.6475 ms | 6 | 11062.5000 | - | - | 34.13 MB |
| Chloe | ChloeBenchmarks | Query | 14.5 ms | 2.2600 ms | 5.3711 ms | 7 | 2375.0000 | 1000.0000 | 312.5000 | 13.07 MB |
| EF | EFBenchmarks | Query_NoTracking | 126.4 ms | 1.3197 ms | 1.2344 ms | 8 | 5937.5000 | 2250.0000 | 1062.5000 | 30.16 MB |
| EF | EFBenchmarks | SqlQuery_NoTracking | 148.6 ms | 0.8290 ms | 0.7755 ms | 9 | 7437.5000 | 2937.5000 | 1250.0000 | 37.79 MB |


4. 安装 (NuGet)

Install-Package SmartSql

5. 常规代码

查询

            ISmartSqlMapper SqlMapper = MapperContainer.Instance.GetSqlMapper();
            SqlMapper.Query<T_Test>(new RequestContext
            {
                Scope = "T_Test",
                SqlId = "GetList",
                Request = new { Ids = new long[] { 1, 2, 3, 4 } }
            });

事务

            try
            {
                ISmartSqlMapper SqlMapper = MapperContainer.Instance.GetSqlMapper();
                SqlMapper.BeginTransaction();
                //BizCode
                SqlMapper.CommitTransaction();
            }
            catch (Exception ex)
            {
                SqlMapper.RollbackTransaction();
                throw ex;
            }

6. 最佳实践

6.1 安装 SmartSql.DIExtension

Install-Package SmartSql.DIExtension

6.2 注入依赖

 services.AddSmartSql();
 services.AddRepositoryFactory();
 services.AddRepositoryFromAssembly((options) =>
 {
    options.AssemblyString = "SmartSql.Starter.Repository";
 });

6.3 定义仓储接口

    /// <summary>
    /// 属性可选: [SqlMap(Scope = "User")] ,不设置 则默认 Scope 模板:I{Scope}Repository
    /// 可传入自定义模板
    /// RepositoryBuilder builder=new RepositoryBuilder("I{Scope}DAL");
    /// </summary>
    public interface IUserRepository
    {
        /// <summary>
        /// 属性可选 [Statement(Execute = ExecuteBehavior.Auto,Id = "Query")]
        /// 默认 Execute:Auto ,自动判断 执行类型
        /// 默认 Id : 方法名
        /// </summary>
        /// <param name="reqParams"></param>
        /// <returns></returns>
        IEnumerable<User> Query(object reqParams);
        long GetRecord(object reqParams);
        User Get(object reqParams);
        long Insert(User entity);
        int Update(User entity);
        int Delete(User enttiy);
    }

6.4 尽情享用

    public class UserService
    {
        private readonly ISmartSqlMapper _smartSqlMapper;
        private readonly IUserRepository _userRepository;

        public UserService(
             ISmartSqlMapper smartSqlMapper
            , IUserRepository userRepository)
        {
            _smartSqlMapper = smartSqlMapper;
            _userRepository = userRepository;
        }

        public long Add(AddRequest request)
        {
            int existsNum = _userRepository.Exists(new { request.UserName });
            if (existsNum > 0)
            {
                throw new ArgumentException($"{nameof(request.UserName)} has already existed!");
            }
            return _userRepository.Add(new Entitiy.User
            {
                UserName = request.UserName,
                Password = request.Password,
                Status = Entitiy.UserStatus.Ok,
                CreationTime = DateTime.Now,
            });
        }

        public void UseTransaction()
        {
            try
            {
                _smartSqlMapper.BeginTransaction();
                //Biz();
                _smartSqlMapper.CommitTransaction();
            }
            catch (Exception ex)
            {
                _smartSqlMapper.RollbackTransaction();
                throw ex;
            }
        }
    }

7. 文档地址

8. 技术交流

点击链接加入QQ群【SmartSql 官方交流群】:604762592

简介

SmartSql-Starter

0. Why

  • 拥抱 跨平台 DotNet Core,是时候了。
  • 把你的双手从数据访问层解放出来,少加点班吧。

1. So SmartSql

  • TargetFrameworks: .NETFramework 4.6 & .NETStandard 2.0
  • SmartSql = MyBatis + Cache(Memory | Redis) + ZooKeeper + R/W Splitting + ......

2. 主要特性 (√ 为已完成,未打 √ 为计划特性)

  • 1 ORM
    • 1.1 Sync
    • 1.2 Async
  • 2 XmlConfig & XmlStatement -> Sql
    • 2.1 SmartSqlMapConfig & SmartSqlMap √ (是的,你猜对了,和MyBatis一样,通过XML配置分离SQL。)
    • 2.2 Config Hot Update ->ConfigWatcher & Reload (配置文件热更新:当你需要修改Sql的时候,直接修改SqlMap配置文件,保存即可。)
  • 3 读写分离 √
    • 3.1 读写分离 √
    • 3.2 多读库 权重筛选 √ (配置多读库,根据读库权重选举读库)
  • 4 日志 √
    • 4.1 基于 Microsoft.Extensions.Logging.Abstractions (当你需要跟踪调试的时候一切都是那么一目了然)
  • 5 Dynamic Repository
    • 5.1 SmartSql.DyRepository √
  • 6 查询缓存 √
    • 6.1 SmartSql.Cache.Memory √
      • 6.1.1 Fifo √
      • 6.1.2 Lru √
    • 6.2 SmartSql.Cache.Redis √
    • 6.3 缓存事务一致性
  • 7 分布式配置插件
    • 7.1 IConfigLoader √ (配置文件加载器)
    • 7.2 LocalFileConfigLoader √ √ (本地文件配置加载器)
      • 7.2.1 Load SmartSqlMapSource Xml √
      • 7.3.1 Load SmartSqlMapSource Directory √
    • 7.3 SmartSql.ZooKeeperConfig √ (ZooKeeper 分布式配置文件加载器)

3. 性能


BenchmarkDotNet=v0.10.14, OS=Windows 10.0.16299.431 (1709/FallCreatorsUpdate/Redstone3)
Intel Core i7-4710MQ CPU 2.50GHz (Haswell), 1 CPU, 8 logical and 4 physical cores
Frequency=2435768 Hz, Resolution=410.5481 ns, Timer=TSC
.NET Core SDK=2.1.201
  [Host]     : .NET Core 2.0.7 (CoreCLR 4.6.26328.01, CoreFX 4.6.26403.03), 64bit RyuJIT
  DefaultJob : .NET Core 2.0.7 (CoreCLR 4.6.26328.01, CoreFX 4.6.26403.03), 64bit RyuJIT

| ORM | Type | Method | Mean | Error | StdDev | Rank | Gen 0 | Gen 1 | Gen 2 | Allocated |
|--------------- |------------------------- |------------------------ |---------:|----------:|----------:|-----:|-----------:|----------:|----------:|----------:|
| SmartSql | SmartSqlBenchmarks | Query | 101.6 ms | 0.2226 ms | 0.1738 ms | 1 | 2437.5000 | 1062.5000 | 375.0000 | 13.37 MB |
| Native | NativeBenchmarks | Query_IsDBNull_GetValue | 101.7 ms | 0.4101 ms | 0.3635 ms | 1 | 2437.5000 | 1062.5000 | 375.0000 | 13.37 MB |
| Dapper | DapperBenchmarks | Query | 104.4 ms | 1.3195 ms | 1.2342 ms | 2 | 3375.0000 | 1375.0000 | 625.0000 | 17.64 MB |
| SmartSqlDapper | SmartSqlDapperBenchmarks | Query | 105.7 ms | 1.1697 ms | 1.0941 ms | 3 | 3750.0000 | 1437.5000 | 625.0000 | 19.47 MB |
| Native | NativeBenchmarks | Query_GetValue_DbNull | 107.4 ms | 1.0710 ms | 1.0018 ms | 4 | 3062.5000 | 1187.5000 | 500.0000 | 16.42 MB |
| SqlSugar | SqlSugarBenchmarks | Query | 108.9 ms | 0.4048 ms | 0.3787 ms | 5 | 2375.0000 | 1000.0000 | 312.5000 | 13.09 MB |
| EF | EFBenchmarks | SqlQuery | 110.9 ms | 0.6922 ms | 0.6475 ms | 6 | 11062.5000 | - | - | 34.13 MB |
| Chloe | ChloeBenchmarks | Query | 14.5 ms | 2.2600 ms | 5.3711 ms | 7 | 2375.0000 | 1000.0000 | 312.5000 | 13.07 MB |
| EF | EFBenchmarks | Query_NoTracking | 126.4 ms | 1.3197 ms | 1.2344 ms | 8 | 5937.5000 | 2250.0000 | 1062.5000 | 30.16 MB |
| EF | EFBenchmarks | SqlQuery_NoTracking | 148.6 ms | 0.8290 ms | 0.7755 ms | 9 | 7437.5000 | 2937.5000 | 1250.0000 | 37.79 MB |


4. 安装 (NuGet)

Install-Package SmartSql

5. 常规代码

查询

            ISmartSqlMapper SqlMapper = MapperContainer.Instance.GetSqlMapper();
            SqlMapper.Query<T_Test>(new RequestContext
            {
                Scope = "T_Test",
                SqlId = "GetList",
                Request = new { Ids = new long[] { 1, 2, 3, 4 } }
            });

事务

            try
            {
                ISmartSqlMapper SqlMapper = MapperContainer.Instance.GetSqlMapper();
                SqlMapper.BeginTransaction();
                //BizCode
                SqlMapper.CommitTransaction();
            }
            catch (Exception ex)
            {
                SqlMapper.RollbackTransaction();
                throw ex;
            }

6. 最佳实践

6.1 安装 SmartSql.DIExtension

Install-Package SmartSql.DIExtension

6.2 注入依赖

 services.AddSmartSql();
 services.AddRepositoryFactory();
 services.AddRepositoryFromAssembly((options) =>
 {
    options.AssemblyString = "SmartSql.Starter.Repository";
 });

6.3 定义仓储接口

    /// <summary>
    /// 属性可选: [SqlMap(Scope = "User")] ,不设置 则默认 Scope 模板:I{Scope}Repository
    /// 可传入自定义模板
    /// RepositoryBuilder builder=new RepositoryBuilder("I{Scope}DAL");
    /// </summary>
    public interface IUserRepository
    {
        /// <summary>
        /// 属性可选 [Statement(Execute = ExecuteBehavior.Auto,Id = "Query")]
        /// 默认 Execute:Auto ,自动判断 执行类型
        /// 默认 Id : 方法名
        /// </summary>
        /// <param name="reqParams"></param>
        /// <returns></returns>
        IEnumerable<User> Query(object reqParams);
        long GetRecord(object reqParams);
        User Get(object reqParams);
        long Insert(User entity);
        int Update(User entity);
        int Delete(User enttiy);
    }

6.4 尽情享用

    public class UserService
    {
        private readonly ISmartSqlMapper _smartSqlMapper;
        private readonly IUserRepository _userRepository;

        public UserService(
             ISmartSqlMapper smartSqlMapper
            , IUserRepository userRepository)
        {
            _smartSqlMapper = smartSqlMapper;
            _userRepository = userRepository;
        }

        public long Add(AddRequest request)
        {
            int existsNum = _userRepository.Exists(new { request.UserName });
            if (existsNum > 0)
            {
                throw new ArgumentException($"{nameof(request.UserName)} has already existed!");
            }
            return _userRepository.Add(new Entitiy.User
            {
                UserName = request.UserName,
                Password = request.Password,
                Status = Entitiy.UserStatus.Ok,
                CreationTime = DateTime.Now,
            });
        }

        public void UseTransaction()
        {
            try
            {
                _smartSqlMapper.BeginTransaction();
                //Biz();
                _smartSqlMapper.CommitTransaction();
            }
            catch (Exception ex)
            {
                _smartSqlMapper.RollbackTransaction();
                throw ex;
            }
        }
    }

7. 文档地址

8. 技术交流

点击链接加入QQ群【SmartSql 官方交流群】:604762592

Showing the top 2 GitHub repositories that depend on SmartSql:

Repository Stars
SkyAPM/SkyAPM-dotnet
The .NET/.NET Core instrument agent for Apache SkyWalking
Shriek-Projects/shriek-fx
【WIP】️一个基于 .NET Core 2.0 开发的简单易用的快速开发框架,遵循领域驱动设计(DDD)规范约束,并结合CQRS架构提供实现事件驱动、事件回溯、响应式等特性的基础设施。让开发者享受到正真意义的面向对象设计模式来带的美感。

Version History

Version Downloads Last updated
4.1.32 44 9/30/2019
4.1.31 33 9/29/2019
4.1.30 34 9/27/2019
4.1.29 36 9/26/2019
4.1.28 55 9/2/2019
4.1.27 44 8/30/2019
4.1.26 40 8/30/2019
4.1.25 41 8/30/2019
4.1.24 59 8/28/2019
4.1.23 78 8/20/2019
4.1.22 56 8/19/2019
4.1.21 74 8/13/2019
4.1.20 62 8/13/2019
4.1.19 64 8/13/2019
4.1.18 96 8/5/2019
4.1.17 76 8/1/2019
4.1.16 69 8/1/2019
4.1.15 67 7/30/2019
4.1.14 66 7/30/2019
4.1.12 68 7/30/2019
4.1.11 69 7/30/2019
4.1.9 70 7/29/2019
4.1.8 67 7/29/2019
4.1.7 65 7/29/2019
4.1.6 69 7/29/2019
4.1.5 66 7/27/2019
4.1.3 71 7/26/2019
4.1.2 67 7/25/2019
4.1.1 65 7/25/2019
4.1.0 69 7/24/2019
4.0.88 67 7/24/2019
4.0.86 69 7/22/2019
4.0.85 70 7/22/2019
4.0.84 70 7/22/2019
4.0.81 72 7/19/2019
4.0.80 67 7/19/2019
4.0.78 68 7/19/2019
4.0.76 78 7/17/2019
4.0.75 99 7/10/2019
4.0.73 85 7/10/2019
4.0.72 109 7/5/2019
4.0.71 156 6/25/2019
4.0.70 87 6/25/2019
4.0.69 85 6/25/2019
4.0.68 106 6/20/2019
4.0.66 103 6/18/2019
4.0.65 98 6/17/2019
4.0.63 115 6/12/2019
4.0.62 86 6/12/2019
4.0.60 127 6/11/2019
4.0.59 90 6/11/2019
4.0.58 191 6/3/2019
4.0.56 145 5/31/2019
4.0.55 125 5/30/2019
4.0.53 105 5/30/2019
4.0.52 102 5/30/2019
4.0.51 105 5/30/2019
4.0.50 111 5/29/2019
4.0.49 97 5/29/2019
4.0.48 126 5/24/2019
4.0.46 207 5/15/2019
4.0.45 150 5/10/2019
4.0.44 157 5/7/2019
4.0.43 106 5/7/2019
4.0.42 239 4/28/2019
4.0.41 111 4/28/2019
4.0.40 156 4/26/2019
4.0.38 140 4/26/2019
4.0.36 136 4/25/2019
4.0.35 132 4/25/2019
4.0.34 203 4/23/2019
4.0.33 171 4/19/2019
4.0.32 156 4/19/2019
4.0.30 116 4/19/2019
4.0.29 152 4/18/2019
4.0.28 129 4/18/2019
4.0.26 134 4/18/2019
4.0.25 117 4/17/2019
4.0.21 130 4/17/2019
4.0.20 134 4/16/2019
4.0.19 154 4/15/2019
4.0.18 133 4/15/2019
4.0.16 150 4/11/2019
4.0.15 122 4/11/2019
4.0.14 146 4/9/2019
4.0.13 124 4/9/2019
4.0.12 192 4/4/2019
4.0.11 113 4/4/2019
4.0.10 156 4/3/2019
4.0.9 122 4/3/2019
4.0.8 128 4/3/2019
4.0.7 118 4/3/2019
4.0.6 117 4/3/2019
4.0.5 122 4/2/2019
4.0.4 116 4/2/2019
4.0.3 494 4/2/2019
4.0.2 125 4/1/2019
4.0.1 126 4/1/2019
4.0.0 206 4/1/2019
4.0.0-rc999 90 3/31/2019
4.0.0-rc998 86 3/29/2019
4.0.0-rc997 100 3/29/2019
4.0.0-rc996 87 3/29/2019
4.0.0-rc995 93 3/28/2019
4.0.0-rc994 89 3/28/2019
4.0.0-rc993 85 3/28/2019
4.0.0-rc991 97 3/27/2019
4.0.0-rc990 102 3/27/2019
4.0.0-rc99 92 3/27/2019
4.0.0-rc98 94 3/26/2019
4.0.0-rc97 91 3/26/2019
4.0.0-rc96 84 3/26/2019
4.0.0-rc95 96 3/25/2019
4.0.0-rc93 85 3/25/2019
4.0.0-rc92 93 3/25/2019
4.0.0-rc91 95 3/22/2019
4.0.0-rc9 104 3/22/2019
4.0.0-rc8 89 3/21/2019
4.0.0-rc6 93 3/21/2019
4.0.0-rc5 94 3/20/2019
4.0.0-rc3 141 3/18/2019
4.0.0-rc2 94 3/18/2019
4.0.0-rc10 91 3/22/2019
4.0.0-rc1 123 3/17/2019
4.0.0-beta5 84 3/16/2019
4.0.0-beta4 93 3/11/2019
4.0.0-beta3 112 3/9/2019
4.0.0-beta2 102 3/8/2019
4.0.0-beta1 99 3/7/2019
3.8.15 382 4/26/2019
3.8.13 122 4/9/2019
3.8.12 560 12/17/2018
3.8.9 121 3/26/2019
3.8.8 194 12/5/2018
3.8.6 221 11/29/2018
3.8.5 156 11/29/2018
3.8.4 951 11/9/2018
3.8.2 414 10/30/2018
3.8.0 174 10/29/2018
3.7.16 967 10/26/2018
3.7.15 437 10/24/2018
3.7.15-rc4 138 10/24/2018
3.7.15-rc2 128 10/23/2018
3.7.13 195 10/22/2018
3.7.12 171 10/22/2018
3.7.11 199 10/21/2018
3.7.10 265 10/11/2018
3.7.9 189 10/10/2018
3.7.8 297 9/30/2018
3.7.6 204 9/28/2018
3.7.5 185 9/26/2018
3.7.3 220 9/26/2018
3.7.2 174 9/25/2018
3.7.1 191 9/25/2018
3.7.0 220 9/18/2018
3.7.0-pre6 184 9/17/2018
3.6.9 197 9/16/2018
3.6.8.2 189 9/12/2018
3.6.8.1 383 9/9/2018
3.6.7 348 9/7/2018
3.6.5 243 9/1/2018
3.6.4 200 8/28/2018
3.6.2 230 8/23/2018
3.6.1 430 8/13/2018
3.6.0 290 8/8/2018
3.6.0-rc2 170 8/7/2018
3.6.0-rc1 174 8/5/2018
3.6.0-pre9 208 8/5/2018
3.6.0-pre8 211 8/5/2018
3.6.0-pre6 208 8/4/2018
3.6.0-pre3 200 8/3/2018
3.6.0-pre1 260 8/3/2018
3.5.14 216 8/2/2018
3.5.13 215 8/2/2018
3.5.12 203 8/2/2018
3.5.11 205 8/2/2018
3.5.10 198 8/1/2018
3.5.9 193 8/1/2018
3.5.8 208 7/31/2018
3.5.5 210 7/31/2018
3.5.3 226 7/25/2018
3.5.2 204 7/25/2018
3.5.1 204 7/25/2018
3.5.0 204 7/24/2018
3.5.0-pre2 202 7/23/2018
3.5.0-pre1 203 7/21/2018
3.4.8 248 7/19/2018
3.4.6 218 7/19/2018
3.4.3 226 7/19/2018
3.4.2 242 7/18/2018
3.4.0 244 7/18/2018
3.3.18 236 7/13/2018
3.3.16 213 7/12/2018
3.3.12 255 7/12/2018
3.3.11 274 7/5/2018
3.3.10 251 7/4/2018
3.3.8 260 7/1/2018
3.3.6 276 6/26/2018
3.3.4 474 6/26/2018
3.3.3 266 6/25/2018
3.3.1 284 6/13/2018
3.2.0 303 6/11/2018
3.1.0 264 6/9/2018
3.0.1 267 6/4/2018
3.0.0 260 6/2/2018
3.0.0-rc93 193 6/1/2018
3.0.0-rc92 222 5/31/2018
3.0.0-rc91 179 5/30/2018
3.0.0-rc8 196 5/29/2018
3.0.0-rc6 212 5/28/2018
3.0.0-rc5 201 5/27/2018
3.0.0-rc4 207 5/18/2018
3.0.0-rc3 199 5/16/2018
3.0.0-pre8 253 5/15/2018
3.0.0-pre4 271 5/12/2018
3.0.0-pre3 264 5/8/2018
3.0.0-pre2 229 5/7/2018
3.0.0-pre1 255 5/6/2018
2.3.2 758 3/25/2018
2.3.0 419 3/24/2018
2.2.8 328 3/8/2018
2.2.6 284 3/6/2018
2.2.2 412 2/5/2018
2.2.1 389 12/27/2017
2.2.0.2 331 12/27/2017
2.2.0.1 339 11/8/2017
2.2.0 318 11/7/2017
2.2.0-preview 289 11/3/2017
2.1.0-preview2 254 11/3/2017
2.0.18.8 265 10/24/2017
2.0.18.6 319 10/13/2017
2.0.18.5 268 10/10/2017
2.0.18.2 261 10/8/2017
2.0.18 298 9/28/2017
2.0.16 316 9/19/2017
2.0.15 315 9/19/2017
2.0.13 335 9/18/2017
2.0.12 311 9/18/2017
2.0.8 262 9/14/2017
2.0.6 259 9/12/2017
2.0.5 297 9/1/2017
2.0.4 279 8/30/2017
2.0.3 341 8/21/2017
2.0.0 292 8/16/2017
2.0.0-preview3-final 268 8/16/2017
2.0.0-preview2-final 323 8/16/2017
1.8.8.2 281 8/16/2017
1.8.8.1 292 8/15/2017
1.8.6.1 329 8/14/2017
1.8.6 327 8/11/2017
1.8.5 285 8/10/2017
1.8.3 275 8/10/2017
1.8.2 284 8/10/2017
1.8.0 293 8/10/2017
1.7.8 277 8/9/2017
1.6.7 339 8/8/2017
1.6.6 405 7/24/2017
1.6.2 416 7/19/2017
1.5.9 393 7/11/2017
1.5.8.1 477 5/27/2017
1.5.8 353 5/25/2017
1.5.5 344 5/23/2017
1.5.3 349 5/22/2017
1.5.2 357 5/22/2017
1.5.0 353 5/20/2017
1.4.9 379 4/25/2017
1.4.8 371 4/25/2017
1.4.4 361 4/21/2017
1.4.3 367 4/20/2017
1.4.2 372 4/20/2017
1.3.1 368 4/18/2017
1.2.0 351 4/17/2017
1.1.0 355 4/13/2017
1.0.4 358 4/7/2017
1.0.2 371 4/3/2017
Show less