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

 更新时间:2022年03月03日 10:27:26   作者:.NET开发菜鸟  
这篇文章介绍了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框架实现多数据库的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • ASP.NET使用ajax实现分页局部刷新页面功能

    ASP.NET使用ajax实现分页局部刷新页面功能

    使用ajax方法实现分页也很简单,主要是两个,ContentTemplate和Trigger。先把listView扔ContentTemplate里面。然后在Trigger里面加入asp:AsyncPostBackTrigger,将ID指向之前的分页控件DataPager控件。具体实现代码大家可以参考下本文
    2017-03-03
  • asp.net(c#) MS AJAX的安装

    asp.net(c#) MS AJAX的安装

    asp.net(c#) MS AJAX的安装...
    2007-06-06
  • 更方便快捷的外部操作数据库的方法(另类玩法)

    更方便快捷的外部操作数据库的方法(另类玩法)

    数据库操作方法很多,各种各样但是外部操作数据库的方法就会显得格外陌生了,感兴趣的朋友可以详细了解下本文,或许对你学习ado.net有所帮助
    2013-02-02
  • asp.net Core中同名服务注册的实现代码

    asp.net Core中同名服务注册的实现代码

    Asp.Net Core中自带了容器,同时也可以使用AutoFac替换掉默认的容器,以下为两种方式同名服务的注册实现,对asp.net Core服务注册的实现代码感兴趣的朋友一起看看吧
    2022-03-03
  • asp.net 产生随机颜色实现代码

    asp.net 产生随机颜色实现代码

    asp.net 随机颜色产生实现代码,需要的朋友拿过去测试一下。
    2009-11-11
  • 解析ABP框架中的事务处理和工作单元

    解析ABP框架中的事务处理和工作单元

    ABP是"ASP.NET Boilerplate Project(ASP.NET样板项目)"的简称,是一个建立在.NET之上的Web开发框架,下面我们来解析ABP框架中的事务处理和工作单元
    2016-06-06
  • 创建一个ASP.NET MVC5项目的实现方法(图文)

    创建一个ASP.NET MVC5项目的实现方法(图文)

    这篇文章主要介绍了创建一个ASP.NET MVC 5项目,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • ASP.NET 2.0写无限级下拉菜单

    ASP.NET 2.0写无限级下拉菜单

    ASP.NET 2.0提供了一个Menu 类,可以方便地创建水平或者垂直方向的下拉菜单,下面就是一个例子:
    2008-12-12
  • ASP.NET中实现获取调用方法名

    ASP.NET中实现获取调用方法名

    这篇文章主要介绍了ASP.NET中实现获取调用方法名的技巧,较为详细的讲述了相关的命名空间的调用及语句执行顺序,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • 在运行时编辑代码的 .NET 热重载的操作方法

    在运行时编辑代码的 .NET 热重载的操作方法

    今天通过本文给大家分享 Visual Studio 2019 中 16.11(预览版1)中的 .NET 热重载(通过 .NET 6(预览版4)中的 dotnet watch 命令行工具),介绍什么是 .NET 热重载,如何使用这个特征,感兴趣的朋友跟随小编一起学习下吧
    2021-07-07

最新评论