FreeSql + .Net6 多库连接实现

news2025/2/28 6:08:06

1、安装Nuget包 AutoMapper

2、program.cs里添加如下配置:

 services.AddSingleton(r =>
 {
     var str = configuration.GetConnectionString("MES");
     return new FreeSqlBuilder()
             .UseConnectionString(DataType.SqlServer, str)
             .Build<MESFlag>();
 });

 services.AddSingleton(r =>
 {
     var str = configuration.GetConnectionString("Kingdee");
     return new FreeSqlBuilder()
             .UseConnectionString(DataType.SqlServer, str)
             .Build<KingdeeFlag>();
 });

3、 创建仓储类 ServiceLocator

  public class ServiceLocator
  {
      #region Field

      private static IServiceProvider _instance;

      #endregion

      #region Public Method

      /// <summary>
      /// 设置IServiceProvider
      /// </summary>
      /// <param name="serviceProvider"></param>
      public static void SetProvider(IServiceProvider serviceProvider)
      {
          if (_instance == null)
              _instance = serviceProvider;
      }

      /// <summary>
      /// 获取服务
      /// </summary>
      /// <typeparam name="T"></typeparam>
      /// <returns></returns>
      public static T GetService<T>()
      {
          return _instance.GetService<T>();
      }

      /// <summary>
      /// 获取服务
      /// </summary>
      /// <typeparam name="T"></typeparam>
      /// <returns></returns>
      public static object GetService(Type type)
      {
          return _instance.GetService(type);
      }

      #endregion
  }

4、program.cs里添加如下配置:

 ServiceLocator.SetProvider(services.BuildServiceProvider());

5、创建ServiceBase类

 public abstract class ServiceBase<T> where T : EntityBase, new()
 {
     /// <summary>
     /// 数据库访问对象1
     /// </summary>
     protected IFreeSql<DB1Flag> FreeSql1
     {
         get
         {
             return ServiceLocator.GetService<IFreeSql<DB1Flag>>();
         }
     }

     /// <summary>
     /// 数据库访问对象2
     /// </summary>
     protected IFreeSql<Db2Flag> FreeSql2
     {
         get
         {
             return ServiceLocator.GetService<IFreeSql<Db2Flag>>();
         }
     }
 }

 /// <summary>
 /// 库1
 /// </summary>
 public class DB1Flag
 { }

 /// <summary>
 /// 库2
 /// </summary>
 public class Db2Flag
 { }

6、创建你自己的Service

  public class YourService : ServiceBase<YourEntity>, IYourService
  {
      private readonly ILogger<YourService> _logger;

      public YourService(ILogger<YourService> logger)
      {
          _logger = logger;
      }

      public List<YourDto> GetList(string name)
      {
         
         
          var list = FreeSql1.Select<YourEntity>().Where(x => x.Name == name).ToList();

          // 访问
          var list2 = FreeSql2.Select<YourEntity>().Where(x=>x.Name == name).ToList();  



          // convert to dto... 

          return null;
      }
  }

7、创建Base实体类

public abstract class EntityBase:EntityBase<long>
{

}

/// <summary>
/// 
/// </summary>
/// <typeparam name="T"></typeparam>
public abstract class EntityBase <T>
{
    /// <summary>
    /// 主键
    /// </summary>
    [Column(IsPrimary = true)]
    [Description("主键")]
    public virtual T Id { get; set; }

}

8、创建你的实体类

[Table(Name = "Tb_Your")]
public class YourEntity : EntityBase
{
    /// <summary>
    /// 姓名
    /// </summary>
    [Column]
    public string Name { get; set; }

    /// <summary>
    /// 备注
    /// </summary>
    [Column(DbType = "text")]
    public string Remark { get; set; }

    #region 关联对象

    /// <summary>
    /// 子表集合
    /// </summary>
    [Navigate(nameof(YourDetailEntity.ParentId))]
    public List<YourDetailEntity> DetailList { get; set; }

    #endregion

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2307236.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

4个小时开发DeepSeek+baiduNaotu一键生成思维导图

一、引言 最近发现AI生成思维导图的解决方案普遍存在两个断层&#xff1a;用户需手动复制模型输出的JSON数据到脑图软件&#xff0c;且缺乏实时可视化反馈。基于日常使用的BaiduNaotu框架&#xff08;其轻量级架构与简洁的UI设计已满足基础需求&#xff09;&#xff0c;我决定…

(21)从strerror到strtok:解码C语言字符函数的“生存指南2”

❤个人主页&#xff1a;折枝寄北的博客 ❤专栏位置&#xff1a;简单入手C语言专栏 目录 前言1. 错误信息报告1.1 strerror 2. 字符操作2.1 字符分类函数2.2 字符转换函数 3. 内存操作函数3.1 memcpy3.2 memmove3.2memset3.3 memcmp 感谢您的阅读 前言 当你写下strcpy(dest, s…

SpringBoot集成easy-captcha图片验证码框架

SpringBoot集成easy-captcha图片验证码框架 此项目已经很久未维护&#xff0c;如有更好的选择&#xff0c;建议使用更好的选择!!! 一、引言 验证码&#xff08;CAPTCHA&#xff09;是现代应用中防止机器人攻击、保护接口安全的核心手段之一。然而&#xff0c;从零开发验证码…

货车一键启动无钥匙进入手机远程启动的正确使用方法

一、移动管家货车无钥匙进入系统的使用方法 基本原理&#xff1a;无钥匙进入系统通常采用RFID无线射频技术和车辆身份识别码识别系统。车钥匙需要随身携带&#xff0c;当车钥匙靠近货车时&#xff0c;它会自动与货车的解码器匹配。开门操作&#xff1a;当靠近货车后&#xff0…

【实战 ES】实战 Elasticsearch:快速上手与深度实践-1.2.2倒排索引原理与分词器(Analyzer)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 1.2.2倒排索引原理与分词器&#xff08;Analyzer&#xff09;1. 倒排索引&#xff1a;搜索引擎的基石1.1 正排索引 vs 倒排索引示例数据对比&#xff1a; 1.2 倒排索引核心结…

和鲸科技携手四川气象,以 AI 的力量赋能四川气象一体化平台建设

气象领域与农业、能源、交通、环境科学等国计民生关键领域紧密相连&#xff0c;发挥着不可替代的重要作用。人工智能技术的迅猛发展&#xff0c;为气象领域突破困境带来了新的契机。AI 技术能够深度挖掘气象大数据中蕴含的复杂信息&#xff0c;助力人类更精准地把握自然规律&am…

linux下java Files.copy 提示文件名过长

linux下java Files.copy 提示文件名过长问题排查 系统运行时执行文件拷贝的功能的时候出现了 文件名称过长的报错提示 查询过资料后整理出了每个操作系统支持最大的文件名称长度 每个操作系统现在的文件长度不一样 Linux的 /usr/include/linux/limits.h 中做出了说明 这些限制…

Metal学习笔记八:纹理

到目前为止&#xff0c;您已经学习了如何使用片段函数和着色器为模型添加颜色和细节。另一种选择是使用图像纹理&#xff0c;您将在本章中学习如何作。更具体地说&#xff0c;您将了解&#xff1a; • UV 坐标&#xff1a;如何展开网格&#xff0c;以便可以对其应用纹理。 • 纹…

Idea 和 Pycharm 快捷键

一、快捷键 二、Pycharm 中怎么切换分支 参考如下 如果在界面右下角 没有看到当前所在的分支&#xff0c;如 “Git:master” 3. 有了 4.

fody引用c++的dll合并后提示找不到

fody引用c的dll合并后提示找不到 解决方案&#xff1a; 在 FodyWeavers.xml 文件中添加配置 CreateTemporaryAssemblies‘true’ 官方文档&#xff1a;https://github.com/Fody/Costura <Weavers xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xsi:noN…

初识flutter1

为什么使用flutter, 说直白一点,就是移动UI框架, 个人认为优势是: 1.一套代码adnroid 和ios 可以使用, 代码好维护 2.原生用户界面 3.开源、免费的 开发工具&#xff1a; 1.下载 java 包, 根据自己的电脑配置选择 官网下载: https://www.oracle.com/java/technologies/download…

12字符函数

一、函数strchr与strrchr 注意&#xff1a; 这两个函数的功能&#xff0c;都是在指定的字符串 s 中&#xff0c;试图找到字符 c。strchr() 从左往右找&#xff0c;strrchr() 从右往左找。字符串结束标记 ‘\0’ 被认为是字符串的一部分。 图解&#xff1a; 示例代码&#xff…

QT6开发高性能企业视频会议-8 使用VSCode+Copilot AI开发

Github Copilot是Github和OpenAI推出的AI编程辅助工具&#xff0c;之前版本的Github Copilot只有简单的代码自动补全&#xff0c;根据注释生成一些代码等辅助功能。 近期Copilot有了一次大的升级&#xff0c;加入了Agent模式&#xff0c;可以实现自然语言对话讨论和最重要的&a…

矩阵的奇异值(SVD)分解和线性变换

矩阵的奇异值&#xff08;SVD&#xff09;分解和线性变换 SVD定义 奇异值分解&#xff08;Singular Value Decomposition&#xff0c;简称 SVD&#xff09;是一种重要的线性代数工具&#xff0c;能够将任意矩阵 ( A ∈ R m n \mathbf{A} \in \mathbb{R}^{m \times n} A∈Rmn…

数据库的sql语句

本篇文章主要用来收集项目开发中&#xff0c;遇到的各种sql语句的编写。 1、根据user表的role_id字段&#xff0c;查询role表。 sql语句&#xff1a;使用JOIN连接两个表 SELECT u.*,r.rolename FROM user u JOIN role r ON u.role_id r.id WHERE u.id 1; 查询结果&#xff1a…

Ubuntu2204下使用NVIDIA GeForce RTX 4090进行DeepSeek-R1-Distill-Llama-8B模型微调

Ubuntu2204下使用NVIDIA GeForce RTX 4090进行DeepSeek-R1-Distill-Llama-8B模型微调 环境准备创建Python微调环境准备数据集准备模型文件 模型微调模型预测原始模型预测微调模型预测 使用unsloth&#xff0c;可以方便地对大模型进行微调。以微调DeepSeek-R1-Distill-Llama-8B为…

Bugku CTF Crypto(二)

目录 这不是md5 贝斯家族 把猪困在猪圈里 黄道十二官&#xff08;宫&#xff09; 抄错的字符 这不是md5 描 述: 666c61677b616537333538376261353662616566357d 分 析&#xff1a;题目提示这不是md5&#xff0c;字符中出现了d&#xff0c;猜测16进制 使用…

单片机总结【GPIO/TIM/IIC/SPI/UART】

一、GPIO 1、概念 通用输入输出口&#xff1b;开发者可以根据自己的需求将其配置为输入或输出模式&#xff0c;以实现与外部设备进行数据交互、控制外部设备等功能。简单来说&#xff0c;GPIO 就像是计算机或微控制器与外部世界沟通的 “桥梁”。 2、工作模式 工作模式性质特…

Rt-thread源码剖析(1)——内核对象

前言 该系列基于rtthread-nano的内核源码&#xff0c;来研究RTOS的底层逻辑&#xff0c;本文介绍RTT的内核对象&#xff0c;对于其他RTOS来说也可供参考&#xff0c;万变不离其宗&#xff0c;大家都是互相借鉴&#xff0c;实现不会差太多。 内核对象容器 首先要明确的一点是什…

十一、大数据治理平台总体功能架构

大数据治理平台的功能架构图中心主题&#xff1a;数据治理 核心重点是建立健全大数据资产管理框架&#xff0c;确保数据质量、安全性、可访问性和合规性。 大数据治理平台总体功能架构图 关键功能领域 1.数据资产平台&#xff08;左侧&#xff09; 此部分主要关注数据资产本身…