使用Spring.Net框架实现多数据库

作者:.NET开发菜鸟 时间:2024-01-14 08:02:22 

一、建立一个空白的解决方案,名称为“SpringDotNot”

二、新建一个类库项目:IBLL

在IBLL类库里面有一个名称为IDatabaseService的接口,接口里面有两个方法:GetDataTableBySQL()和GetDbTyoe()。

代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;

namespace IBLL
{
   /// <summary>
   /// 数据库服务接口
   /// </summary>
   public interface IDatabaseService
   {
       /// <summary>
       /// 根据SQL语句查询数据
       /// </summary>
       /// <returns></returns>
       DataTable GetDataTableBySQL();

/// <summary>
       /// 获取数据库类型
       /// </summary>
       /// <returns></returns>
       string GetDbTyoe();
   }
}

三、新建一个类库项目:BLLMsSql

BLLMsSql表示使用SqlServer数据库实现IBLL里面的接口,BLLMsSql要添加IBLL.dll的引用,代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using IBLL;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;

namespace BLLMsSql
{
   /// <summary>
   /// SqlServer服务类,实现IDatabaseService接口
   /// </summary>
   public class SqlServerService :IDatabaseService
   {
       public DataTable GetDataTableBySQL()
       {
           string strConn = ConfigurationManager.ConnectionStrings["SqlServer"].ConnectionString;
           DataTable dt = new DataTable();
           using (SqlConnection conn = new SqlConnection(strConn))
           {
               try
               {
                   string str = "select * from PtInfectionCard";
                   SqlCommand cmd = new SqlCommand(str, conn);
                   SqlDataAdapter adapter = new SqlDataAdapter(cmd);
                   conn.Open();
                   adapter.Fill(dt);
               }
               catch (Exception ex)
               {

}
               finally
               {
                   conn.Close();
               }

}
           return dt;
       }

/// <summary>
       /// 返回SqlServer数据库
       /// </summary>
       /// <returns></returns>
       public string GetDbTyoe()
       {
           return "我是SQLServer数据库";
       }
   }
}

四、新建一个类库项目:BLLOracle

BLLOracle表示使用Oracle数据库实现IBLL里面的接口,BLLOracle要添加IBLL.dll的引用,代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using IBLL;
using System.Data;
using System.Data.OracleClient;
using System.Configuration;

namespace BLLOracle
{
   /// <summary>
   /// Oracle数据服务类,实现IDatabaseService接口
   /// </summary>
   public class OracleService :IDatabaseService
   {
       public DataTable GetDataTableBySQL()
       {
           string strConn = ConfigurationManager.ConnectionStrings["ORACLE"].ConnectionString;
           DataTable dt = new DataTable();
           using (OracleConnection conn = new OracleConnection(strConn))
           {
               try
               {
                   string str = "select * from emp";
                   OracleCommand cmd = new OracleCommand(str, conn);
                   OracleDataAdapter adapter = new OracleDataAdapter(cmd);
                   conn.Open();
                   adapter.Fill(dt);
               }
               catch (Exception ex)
               {

}
               finally
               {
                   conn.Close();
               }
           }

return dt;
       }

/// <summary>
       /// 返回Oracle数据库
       /// </summary>
       /// <returns></returns>
       public string GetDbTyoe()
       {
           return "我是Oracle数据库";
       }
   }
}

五、客户端调用

添加一个winform应用程序,界面上有一个DataGridView和一个Button按钮,点击Button按钮的时候,从数据库里面取数据并通过DataGridView展示查询出的数据,界面设计如下:

使用Spring.Net框架实现多数据库

Spring.Net的配置信息都写在项目的配置文件(即App.config)中,配置文件如下:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
 <configSections>
   <!--注册spring的切面-->
   <sectionGroup name="spring">
     <!--注册spring的上下文切面-->
     <section name="context" type="Spring.Context.Support.ContextHandler,Spring.Core"/>
     <!--注册spring的对象切面-->
     <section name="objects" type="Spring.Context.Support.DefaultSectionHandler,Spring.Core"/>
   </sectionGroup>
 </configSections>
 <!--Spring的依赖注入配置-->
 <spring>
   <context>
     <!--使用配置文件里面spring节点下面objects节点里面的资源-->
     <resource uri="config://spring/objects"/>
   </context>
   <!--objects节点内配置需要注入到spring容器内的类-->
   <objects xmlns="http://www.springframework.net">
       <!--type组成: 逗号前面是命名空间.类名 逗号后面是程序集名称-->
      <object id="bll" type="BLLOracle.OracleService,BLLOracle"/>
   </objects>
 </spring>
 <connectionStrings>
   <!--Oracle数据库连接字符串-->
   <add name="ORACLE" connectionString="Data Source=127.0.0.1/orcl;Persist Security Info=True;User ID=scott;Password=tiger;Unicode=True;"/>
   <!--SqlServer数据库连接字符串-->
   <add name="SqlServer" connectionString="Data Source=.;Initial Catalog=******;Persist Security Info=True;User ID=******;Password=*********"/>
 </connectionStrings>
   <startup>
       <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/>
   </startup>
</configuration>

后台代码如下:

using Spring.Context;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using IBLL;

namespace WinClient
{
   public partial class FrmMain : Form
   {
       public FrmMain()
       {
           InitializeComponent();
       }

/// <summary>
       /// 加载数据
       /// </summary>
       /// <param name="sender"></param>
       /// <param name="e"></param>
       private void btn_LoadData_Click(object sender, EventArgs e)
       {
           // 从配置文件读取配置
           IApplicationContext ctx = Spring.Context.Support.ContextRegistry.GetContext();
           // 获取具体的实现类
           IDatabaseService dbService = ctx.GetObject("bll") as IDatabaseService;
           // 从数据库查询数据
           DataTable dt = dbService.GetDataTableBySQL();
           // 将查询出的数据绑定到DataGridView中
           this.dgv_Demo.DataSource = dt;
       }
   }
}

配置文件中设置的是使用OracleService实现类,所以程序运行结果:

使用Spring.Net框架实现多数据库

如果要使用SqlServer数据库,只需要修改配置文件中object节点中type的属性值即可:

<object id="bll" type="BLLMsSql.SqlServerService,BLLMsSql"/>

改成使用SqlServer数据库以后的运行结果:

使用Spring.Net框架实现多数据库

来源:https://www.cnblogs.com/dotnet261010/p/7374219.html

标签:Spring.Net,框架,多,数据库
0
投稿

猜你喜欢

  • Pycharm 设置默认解释器路径和编码格式的操作

    2021-10-26 19:19:54
  • Python基础之数据类型相关知识总结

    2021-08-05 07:04:43
  • 女神相册密码忘记了 我只用Python写了20行代码

    2021-05-01 13:27:11
  • 五个提升Python的执行效率的技巧分享

    2021-01-07 09:52:45
  • Python一些基本的图像操作和处理总结

    2022-02-24 05:46:33
  • SQL Server中row_number函数用法入门介绍

    2024-01-26 22:45:04
  • SQLServer2005 没有日志文件(*.ldf) 只有数据文件(*.mdf) 恢复数据库的方法

    2024-01-24 00:15:37
  • Mac PyCharm中的.gitignore 安装设置教程

    2023-02-23 16:48:14
  • mysql 8.0.18 压缩包安装及忘记密码重置所遇到的坑

    2024-01-28 18:01:35
  • python如何调用字典的key

    2023-09-02 01:57:52
  • 关于设计规范

    2008-06-02 13:10:00
  • javascript设计模式之模块模式学习笔记

    2024-04-29 13:16:11
  • 使用Python脚本zabbix自定义key监控oracle连接状态

    2021-01-02 05:23:54
  • ASP+JAVAScript:复杂表单的动态生成与验证

    2007-10-06 21:51:00
  • 一文搞懂Python中列表List和元组Tuple的使用

    2022-10-09 02:24:58
  • Python实现图像的垂直投影示例

    2023-12-06 13:20:15
  • Python相互导入的问题解决

    2022-12-04 16:59:56
  • Python去除列表中重复元素的方法

    2021-06-23 20:44:27
  • Python中将字典转换为XML以及相关的命名空间解析

    2022-07-22 20:05:03
  • Python基础入门之魔法方法与异常处理

    2021-07-01 07:29:39
  • asp之家 网络编程 m.aspxhome.com