Spring.Net框架三:使用Spring.Net框架实现多数据库
在前面的两篇文章中简单介绍了Spring.Net和如何搭建Spring.Net的环境,在本篇文章中将使用Spring.Net实现多数据库的切换。
一、建立一个空白的解决方案,名称为“SpringDotNot”
二、新建一个类库项目:IBLL
在IBLL类库里面有一个名称为IDatabaseService的接口,接口里面有两个方法:GetDataTableBySQL()和GetDbTyoe()。
代码如下:
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 using System.Data; 7 8 namespace IBLL 9 { 10 /// <summary> 11 /// 数据库服务接口 12 /// </summary> 13 public interface IDatabaseService 14 { 15 /// <summary> 16 /// 根据SQL语句查询数据 17 /// </summary> 18 /// <returns></returns> 19 DataTable GetDataTableBySQL(); 20 21 /// <summary> 22 /// 获取数据库类型 23 /// </summary> 24 /// <returns></returns> 25 string GetDbTyoe(); 26 } 27 }
三、新建一个类库项目:BLLMsSql
BLLMsSql表示使用SqlServer数据库实现IBLL里面的接口,BLLMsSql要添加IBLL.dll的引用,代码如下:
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 using IBLL; 7 using System.Data; 8 using System.Data.SqlClient; 9 using System.Configuration; 10 11 namespace BLLMsSql 12 { 13 /// <summary> 14 /// SqlServer服务类,实现IDatabaseService接口 15 /// </summary> 16 public class SqlServerService :IDatabaseService 17 { 18 public DataTable GetDataTableBySQL() 19 { 20 string strConn = ConfigurationManager.ConnectionStrings["SqlServer"].ConnectionString; 21 DataTable dt = new DataTable(); 22 using (SqlConnection conn = new SqlConnection(strConn)) 23 { 24 try 25 { 26 string str = "select * from PtInfectionCard"; 27 SqlCommand cmd = new SqlCommand(str, conn); 28 SqlDataAdapter adapter = new SqlDataAdapter(cmd); 29 conn.Open(); 30 adapter.Fill(dt); 31 } 32 catch (Exception ex) 33 { 34 35 36 } 37 finally 38 { 39 conn.Close(); 40 } 41 42 } 43 return dt; 44 } 45 46 /// <summary> 47 /// 返回SqlServer数据库 48 /// </summary> 49 /// <returns></returns> 50 public string GetDbTyoe() 51 { 52 return "我是SQLServer数据库"; 53 } 54 } 55 }
四、新建一个类库项目:BLLOracle
BLLOracle表示使用Oracle数据库实现IBLL里面的接口,BLLOracle要添加IBLL.dll的引用,代码如下:
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 using IBLL; 7 using System.Data; 8 using System.Data.OracleClient; 9 using System.Configuration; 10 11 namespace BLLOracle 12 { 13 /// <summary> 14 /// Oracle数据服务类,实现IDatabaseService接口 15 /// </summary> 16 public class OracleService :IDatabaseService 17 { 18 public DataTable GetDataTableBySQL() 19 { 20 string strConn = ConfigurationManager.ConnectionStrings["ORACLE"].ConnectionString; 21 DataTable dt = new DataTable(); 22 using (OracleConnection conn = new OracleConnection(strConn)) 23 { 24 try 25 { 26 string str = "select * from emp"; 27 OracleCommand cmd = new OracleCommand(str, conn); 28 OracleDataAdapter adapter = new OracleDataAdapter(cmd); 29 conn.Open(); 30 adapter.Fill(dt); 31 } 32 catch (Exception ex) 33 { 34 35 } 36 finally 37 { 38 conn.Close(); 39 } 40 } 41 42 return dt; 43 } 44 45 /// <summary> 46 /// 返回Oracle数据库 47 /// </summary> 48 /// <returns></returns> 49 public string GetDbTyoe() 50 { 51 return "我是Oracle数据库"; 52 } 53 } 54 }
五、客户端调用
添加一个winform应用程序,界面上有一个DataGridView和一个Button按钮,点击Button按钮的时候,从数据库里面取数据并通过DataGridView展示查询出的数据,界面设计如下:
Spring.Net的配置信息都写在项目的配置文件(即App.config)中,配置文件如下:
1 <?xml version="1.0" encoding="utf-8"?> 2 <configuration> 3 <configSections> 4 <!--注册spring的切面--> 5 <sectionGroup name="spring"> 6 <!--注册spring的上下文切面--> 7 <section name="context" type="Spring.Context.Support.ContextHandler,Spring.Core"/> 8 <!--注册spring的对象切面--> 9 <section name="objects" type="Spring.Context.Support.DefaultSectionHandler,Spring.Core"/> 10 </sectionGroup> 11 </configSections> 12 <!--Spring的依赖注入配置--> 13 <spring> 14 <context> 15 <!--使用配置文件里面spring节点下面objects节点里面的资源--> 16 <resource uri="config://spring/objects"/> 17 </context> 18 <!--objects节点内配置需要注入到spring容器内的类--> 19 <objects xmlns="http://www.springframework.net"> 20 <!--type组成: 逗号前面是命名空间.类名 逗号后面是程序集名称--> 21 <object id="bll" type="BLLOracle.OracleService,BLLOracle"/> 22 </objects> 23 </spring> 24 <connectionStrings> 25 <!--Oracle数据库连接字符串--> 26 <add name="ORACLE" connectionString="Data Source=127.0.0.1/orcl;Persist Security Info=True;User ID=scott;Password=tiger;Unicode=True;"/> 27 <!--SqlServer数据库连接字符串--> 28 <add name="SqlServer" connectionString="Data Source=.;Initial Catalog=******;Persist Security Info=True;User ID=******;Password=*********"/> 29 </connectionStrings> 30 <startup> 31 <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/> 32 </startup> 33 </configuration>
后台代码如下:
1 using Spring.Context; 2 using System; 3 using System.Collections.Generic; 4 using System.ComponentModel; 5 using System.Data; 6 using System.Drawing; 7 using System.Linq; 8 using System.Text; 9 using System.Threading.Tasks; 10 using System.Windows.Forms; 11 using IBLL; 12 13 namespace WinClient 14 { 15 public partial class FrmMain : Form 16 { 17 public FrmMain() 18 { 19 InitializeComponent(); 20 } 21 22 /// <summary> 23 /// 加载数据 24 /// </summary> 25 /// <param name="sender"></param> 26 /// <param name="e"></param> 27 private void btn_LoadData_Click(object sender, EventArgs e) 28 { 29 // 从配置文件读取配置 30 IApplicationContext ctx = Spring.Context.Support.ContextRegistry.GetContext(); 31 // 获取具体的实现类 32 IDatabaseService dbService = ctx.GetObject("bll") as IDatabaseService; 33 // 从数据库查询数据 34 DataTable dt = dbService.GetDataTableBySQL(); 35 // 将查询出的数据绑定到DataGridView中 36 this.dgv_Demo.DataSource = dt; 37 } 38 } 39 }
配置文件中设置的是使用OracleService实现类,所以程序运行结果:
如果要使用SqlServer数据库,只需要修改配置文件中object节点中type的属性值即可:
<object id="bll" type="BLLMsSql.SqlServerService,BLLMsSql"/>
改成使用SqlServer数据库以后的运行结果:
分类:
开发框架
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决