zoukankan      html  css  js  c++  java
  • 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数据库以后的运行结果:

  • 相关阅读:
    前端笔记-jquery
    git的使用
    前端笔记-bom
    微信小程序没找到构建npm或者没找到node_modules目录
    微信小程序判断 wx:if wx:else
    微信小程序提示云函数部署不成功
    cmd如何进入文件夹
    微信小程序view居中
    vue页面跳转兄弟组件传值
    vue全局变量apiurl
  • 原文地址:https://www.cnblogs.com/dotnet261010/p/7374219.html
Copyright © 2011-2022 走看看