.NET 读写分离 操作数据库 ORM 框架
2022/2/16 19:11:50
本文主要是介绍.NET 读写分离 操作数据库 ORM 框架,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
SqlSugar ORM完美支持了计写分离,使用超级简单,只要配置连接字符串即可
读写分离:配置从表
1.如果存在事务所有操作都走主库,不存在事务 修改、写入、删除走主库,查询操作走从库
2.HitRate 越大走这个从库的概率越大
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() { ConnectionString = Config.ConnectionString,//主库 DbType = DbType.SqlServer, IsAutoCloseConnection = true, //从库 SlaveConnectionConfigs = new List<SlaveConnectionConfig>() { new SlaveConnectionConfig() { HitRate=10, ConnectionString=Config.ConnectionString2 } , new SlaveConnectionConfig() { HitRate=10, ConnectionString=Config.ConnectionString2 } } }); //查询 走从库 var list = db.Queryable<Student>().ToList(); //插入 走主库 db.Insertable(new Student() { SchoolId = 1, Name = "jack" }).ExecuteCommand(); //更新 走主库 db.Updateable(new Student() { Id = 1, SchoolId = 2, Name = "jack2" }).ExecuteCommand(); //删除 走主库 db.Deleteable<Student>().Where(it => it.Id == 1).ExecuteCommand();
配置主从复制
ORM是只把读和写进行了请求处理,数据库的主从复制,数据库的同步需要去数据库里面配置
例如: SqlServer有订阅 或者 alwayson等
为什么要读写分离?
降低数据库服务器的压力
如何实现读写分离?
1.一个主库多个从库
2.配置主库复制数据到从库
为什么一个主库多个从库?
一般查询多于增删改,这就是我们常说的二八原则,20%操作是增删改,80%操作是查询
是否有缺点?
有延迟
如何解决延迟问题?
比较及时性的数据还是通过主库查询
具体如何实现?
通过发布服务器,主库发布,而从库订阅,从而实现主从库
实现
SqlServer 实现
1.使用SqlServer 2019,新建一个主库,创建表,再通过本地发布创建发布,
然后通过本地订阅订阅主库,创建两个从库
2.配置AlwaysOn高可用性
https://www.cnblogs.com/chenmh/p/4484176.html
这篇关于.NET 读写分离 操作数据库 ORM 框架的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2022-03-01沐雪多租宝商城源码从.NetCore3.1升级到.Net6的步骤
- 2024-12-06使用Microsoft.Extensions.AI在.NET中生成嵌入向量
- 2024-11-18微软研究:RAG系统的四个层次提升理解与回答能力
- 2024-11-15C#中怎么从PEM格式的证书中提取公钥?-icode9专业技术文章分享
- 2024-11-14云架构设计——如何用diagrams.net绘制专业的AWS架构图?
- 2024-05-08首个适配Visual Studio平台的国产智能编程助手CodeGeeX正式上线!C#程序员必备效率神器!
- 2024-03-30C#设计模式之十六迭代器模式(Iterator Pattern)【行为型】
- 2024-03-29c# datetime tryparse
- 2024-02-21list find index c#
- 2024-01-24convert toint32 c#