使用Spring.Net框架实现多数据库
一、建立一个空白的解决方案,名称为“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的配置信息都写在项目的配置文件(即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实现类,所以程序运行结果:
如果要使用SqlServer数据库,只需要修改配置文件中object节点中type的属性值即可:
<object id="bll" type="BLLMsSql.SqlServerService,BLLMsSql"/>
改成使用SqlServer数据库以后的运行结果:
到此这篇关于Spring.Net框架实现多数据库的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
ABP(现代ASP.NET样板开发框架)系列之二、ABP入门教程详解
ABP是为新的现代Web应用程序使用最佳实践和使用最流行工具的一个起点。可作为一般用途的应用程序的基础框架或项目模板。接下来通过本文给大家详细介绍ABP入门教程,感兴趣的朋友一起看看吧2017-10-10Image显示服务器上任意绝对路径下的图片(采用二进制流实现)
有这样一个需求:数据库中存储的是照片所在的绝对路径(可以不在系统所在路径下),Image控件动态加载路径下的图片,另类实现方法,感兴趣的朋友可以参考下,或许本文对你学习二进制流有所帮助2013-02-02ASP.NET Core使用MiniProfiler分析应用
这篇文章介绍了ASP.NET Core使用MiniProfiler分析应用的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-02-02
最新评论