C#FreeSql分库分表

复制代码
using FreeSql;
using FreeSql.DataAnnotations;

namespace FreeSqlMaster
{
    internal class Program
    {
        static IFreeSql freeSql = null;

        static void Main(string[] args)
        {
            // 读写分离
            // FreeSql 实现了第3种方案,支持一个【主库】多个【从库】,【从库】的查询策略为随机方式。
            // 若某【从库】发生故障,将切换到其他可用【从库】,若已全部不可用则使用【主库】查询。
            // 出现故障【从库】被隔离起来间隔性的检查可用状态,以待恢复
            var connstr_master = "server=127.0.0.1;port=3306;database=test;user=root;password=root;charset=utf8;SslMode=none;Pooling=true;Min Pool Size=0;Max Pool Size=100;Charset=utf8";
            var connstr_slave1 = "server=127.0.0.1;port=3306;database=test1;user=root;password=root;charset=utf8;SslMode=none;Pooling=true;Min Pool Size=0;Max Pool Size=100;Charset=utf8";
            var connstr2_mysql = "server=127.0.0.1;port=3306;database=test;user=root;password=root;charset=utf8;SslMode=none;Pooling=true;Min Pool Size=0;Max Pool Size=100;Charset=utf8";

            freeSql = new FreeSql.FreeSqlBuilder()
                .UseConnectionString(FreeSql.DataType.MySql, connstr_master)
                .UseAutoSyncStructure(true) // 自动同步实体结构到数据库
                                            //.UseSlave(connstr_slave1)//, "connstr_sqlserver2") //使用从数据库,支持多个
                                            //.UseSlaveWeight()
                .Build();

            //Student model = new Student() { Name = "1" };
            //freeSql.Insert(model).ExecuteAffrows();
            freeSql.Update<Student>().SetSource(model).ExecuteAffrows();

            //var d = freeSql.Select<Student>().Where(x => x.Name == "1").First(); //select.Where(a => a.Id == 1).ToOne(); //读【从库】(默认) //select.Master().WhereId(a => a.Id == 1).ToOne(); //强制读【主库】  

            // 分表
            //freeSql.Select<Log>().Any();
            var logRepository = freeSql.GetGuidRepository<Log>(null, oldname => $"{oldname}_201903");
            logRepository.Insert( new Log() { Content = "201903" });
            logRepository.Update(new Log() { Content = "111", Id = 1 });
            logRepository.Delete(new Log() { Id = 1 });

            logRepository = freeSql.GetGuidRepository<Log>(null, oldname => $"{oldname}_201904");
            logRepository.Insert(new Log() { Content = "201904" });

            // 跨表查询
            var sql = freeSql.Select<Log>()
                    .AsTable((type, oldname) => "Log_201903")
                    .AsTable((type, oldname) => "Log_201904")
                    .ToList();// a => a.Id

            // 分库 
            IdleBus<IFreeSql> ib = new IdleBus<IFreeSql>(TimeSpan.FromMinutes(10)); 
            ib.Register("test", () => new FreeSqlBuilder().UseConnectionString(DataType.MySql, connstr_master).Build());
            ib.Register("test1", () => new FreeSqlBuilder().UseConnectionString(DataType.MySql, connstr_slave1).Build()); 
            var lst1 = ib.Get("test").Select<Student>().Limit(10).ToList();
            var lst2 = ib.Get("test1").Select<Student>().Limit(10).ToList();

            Console.ReadKey();
        }

        public class Student
        {
            [Column(Name = "id", IsIdentity = true, IsPrimary = true)]
            public int Id { get; set; }
            public string Name { get; set; }
        }

        public class Log
        {
            [Column(Name = "id", IsIdentity = true, IsPrimary = true)]
            public int Id { get; set; }
            public string Content { get; set; }
        }
    }
}
相关推荐
PfCoder1 天前
C#中定时器之System.Timers.Timer
c#·.net·visual studio·winform
JMchen1231 天前
现代Android图像处理管道:从CameraX到OpenGL的60fps实时滤镜架构
android·图像处理·架构·kotlin·android studio·opengl·camerax
快点好好学习吧1 天前
phpize 依赖 php-config 获取 PHP 信息的庖丁解牛
android·开发语言·php
是誰萆微了承諾1 天前
php 对接deepseek
android·开发语言·php
Dxy12393102161 天前
MySQL如何加唯一索引
android·数据库·mysql
冠希陈、1 天前
PHP 判断是否是移动端,更新鸿蒙系统
android·开发语言·php
人工智能AI技术1 天前
【C#程序员入门AI】本地大模型落地:用Ollama+C#在本地运行Llama 3/Phi-3,无需云端
人工智能·c#
晚霞的不甘1 天前
Flutter for OpenHarmony从零到一:构建《冰火人》双人合作闯关游戏
android·flutter·游戏·前端框架·全文检索·交互
2601_949833391 天前
flutter_for_openharmony口腔护理app实战+饮食记录实现
android·javascript·flutter