本文整理自网络,侵删。
目录
- 一、大家是否有这个需求
- 二、 多库架构ORM
- 三、跨服务器跨库联表查询
- 3.1 跨库查询之一对一
- 3.2 跨库查询之一对多
- 3.3 跨库查询之多对多
- 3.4 多个表查询我们可以这么写
- 3.5 手动指定多库
- 3.6是否有性能问题
.NET 6 跨服务器联表查询, MySql、Oracle、SqlServer等相互联表
一、大家是否有这个需求
1.跨品种查询 :比如 MYSQL和一个SQLSERVER进行联表查询 ,或者SQLITE和MYSQL进行联表查询
2.跨服务器查询 : A服务器和B服务器查询
如果想同时支持1和2 相信很多人都没有比较好的解决方案
我的设计是通过多库架构来实现多库操作
二、 多库架构ORM
什么是多库架构ORM,一个对象可以同时操作和管理多个数据库 我们称为多库架构
EF Core
一个对象只能操作一个数据库,所以EF Core不能称为多库架构,只能称为支持多种数据库,如果要实现多库
我们就需外部封装,代码如下
SqlSugar
SqlSugar在2017最火的时候停更了一年半,最大的原因就是因为底层架构影响了SqlSugar的上限,历史遗留问题太多
需要大量重构,如果直接更新对现有用户是不负责的,所以我选择了一年半未更新,让不是特别热爱SqlSugar的用户
先用其他框架,留下对于SqlSugar一直热衷的用户,能支持和一起完善SqlSugar的用户,谢谢有一群这样的用户不离不弃
筹划了一年半的时间终于在2020开始进行重构 每隔一个月就重构一部分 加点功能 , 直到今天终于重构完成
代码如下:
var db = new SqlSugarClient(new List<ConnectionConfig>() { new ConnectionConfig(){ConfigId="0",DbType=DbType.SqlServer,ConnectionString=..,IsAutoCloseConnection=true}, new ConnectionConfig(){ConfigId="1",DbType=DbType.MySql,ConnectionString=..,IsAutoCloseConnection=true } }); if(!db.IsAnyConnection(configId))//当前上下文不存在则添加 db.AddConnection(new ConnectionConfig{ DbType = DbType.SqlServer,ConfigId = "1", IsAutoCloseConnection = true, ConnectionString = 。。 }); //开启事务 try { //db我们称为主Db db.BeginTran(); //开启多库 (db.Ado.BeginTran是单库事务)事务支持单库和多库 db.GetConnection("1").Insertable(new Order()//var childDb=db.GetConnection(1);我们称为子DB,子DB不具有租户方法,具有单当库操作方法 { CreateTime = DateTime.Now, CustomId = 1, Name = "a", Price = 1 }).ExecuteCommand(); db.GetConnection("2").Insertable(new Order() { CreateTime = DateTime.Now, CustomId = 1, Name = "a", Price = 1 }).ExecuteCommand(); //提交事务 db.CommitTran(); } catch(Exception ex) { //回滚事务 db.Rollback(); }
多库架构可以在底层做到兼容,比如事务不需要引用外部DLL,比如我可以让底层语法支持多库,像EF CORE你能改他的
相关阅读 >>
android开发实现的导出数据库到excel表格功能【附源码下载】
python实现读取txt文件数据并存进内置数据库Sqlite3的方法
c#操作Sqlite数据库方法小结(创建,连接,插入,查询,删除等)
更多相关阅读请进入《Sqlite》频道 >>

数据库系统概念 第6版
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » .NET6跨服务器联表查询操作MySql、Oracle、SqlServer等相互联表
相关推荐
评论
管理员已关闭评论功能...