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数据库以后的运行结果:

posted @ 2017-08-16 16:49  .NET开发菜鸟  阅读(1260)  评论(0编辑  收藏  举报