返回顶部
首页 > 资讯 > 后端开发 > ASP.NET >使用Spring.Net框架实现多数据库
  • 951
分享到

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

2024-04-02 19:04:59 951人浏览 独家记忆
摘要

一、建立一个空白的解决方案,名称为“springDotNot” 二、新建一个类库项目:IBLL 在IBLL类库里面有一个名称为IDatabaseService

一、建立一个空白的解决方案,名称为“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框架实现多数据库的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: 使用Spring.Net框架实现多数据库

本文链接: https://lsjlt.com/news/141153.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 使用Spring.Net框架实现多数据库
    一、建立一个空白的解决方案,名称为“SpringDotNot” 二、新建一个类库项目:IBLL 在IBLL类库里面有一个名称为IDatabaseService...
    99+
    2024-04-02
  • thinkPHP5框架如何实现多数据库连接
    这篇文章将为大家详细讲解有关thinkPHP5框架如何实现多数据库连接,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:1. 多数据库连接方法1:在需要连接其他数据库的地方,使用Db::connec...
    99+
    2023-06-15
  • 使用spring框架实现数据库事务处理方式
    目录使用spring框架实现数据库事务处理JDBC对数据库事务处理的支持JDBC定义了五种事务隔离级别来解决这些并发导致的问题在spring框架中调用一个数据库事务处理分三步走:sp...
    99+
    2024-04-02
  • 使用Django框架中ORM系统实现对数据库数据增删改查
    目录1.数据的增删改查----------增加数据在视图函数中导入User模型类,然后使用下面的方法添加数据:2.数据的增删改查----------查找数据这时在定义模型类时定义的_...
    99+
    2024-04-02
  • Laravel框架中如何使用MongoDB数据库
    这篇文章主要为大家展示了“Laravel框架中如何使用MongoDB数据库”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Laravel框架中如何使用MongoDB数据库”这篇文章吧。先确定好自己...
    99+
    2023-06-29
  • PHPlaravel实现配置使用多数据库
    有的时候,我们在开发的过程中需要连接多个数据库。 Laravel框架中早已为我们想到了这样的需求。 配置很简单。 在根目录下的/config/database.php文件中配置: L...
    99+
    2022-11-13
    PHP laravel配置多数据库 PHP laravel 数据库 PHP laravel
  • .Net使用分表分库框架ShardingCore实现多字段分片
    目录介绍项目地址背景原理直接开始添加依赖创建一个订单对象创建DbContext创建分片路由ShardingCore启动配置测试默认配置下的测试测试无路由返回默认值总结介绍 本期主角:...
    99+
    2024-04-02
  • 使用Spring.Net如何实现控制反转IoC
    今天就跟大家聊聊有关使用Spring.Net如何实现控制反转IoC,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Spring.Net包括控制反转(IoC) 和面向切面(AOP)一、首...
    99+
    2023-05-31
    spring.net ioc
  • Laravel 框架中使用 MongoDB 数据库的操作
    1、先确定好自己使用的哪个版本的 Laravel 框架,再决定 composer 哪一个的 MongoDB,我使用的是 Laravel 8 所以我 composer 了 3.8 的M...
    99+
    2024-04-02
  • .Net如何使用分表分库框架ShardingCore实现多字段分片
    小编给大家分享一下.Net如何使用分表分库框架ShardingCore实现多字段分片,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!原理我们现在假定一个很简单的场景,依然是订单时间按月分片,查询进行如下语句//这边演示不使用...
    99+
    2023-06-22
  • 怎么用SimpleFramework框架实现数据访问
    本篇内容介绍了“怎么用SimpleFramework框架实现数据访问”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Simple数据访问层基于...
    99+
    2023-06-17
  • PHP使用ORM框架连接数据库的方法
    PHP使用ORM框架连接数据库的方法ORM(Object-Relational Mapping)框架是一种将对象模型和关系型数据库模型进行映射的技术。它可以让开发者使用对象的方式来操作数据库,从而避免了手写SQL语句的繁琐和容易出错的问题。...
    99+
    2023-05-15
    PHP 数据库连接 ORM框架
  • PHP中怎么使用ORM框架连接数据库
    这篇文章主要介绍“PHP中怎么使用ORM框架连接数据库”,在日常操作中,相信很多人在PHP中怎么使用ORM框架连接数据库问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP中怎么使用ORM框架连接数据库”的疑...
    99+
    2023-07-06
  • 若依框架引入多数据源,主库MySQL,从库SQLServer。
    若依框架引入多数据源,主库MySQL,从库SQLServer。 1、在 application-druid.yml 添加数据库连接如下: 从数据源开关/默认关闭enabled: trueurl: ...
    99+
    2023-09-04
    sqlserver mysql 数据库
  • 如何使用 Python 框架的 HTTP API 实现数据交换?
    当今互联网时代,数据交换是各种应用程序之间必不可少的一部分。Python框架的HTTP API是一种常用的数据交换方式,本文将介绍如何使用Python框架的HTTP API实现数据交换。 一、什么是HTTP API? HTTP API是一种...
    99+
    2023-10-06
    框架 api http
  • C#使用ADO.Net连接数据库与DbProviderFactory实现多数据库访问
    一、ADO.Net数据库连接字符串 1、OdbcConnection(System.Data.Odbc) (1)SQL Sever 标准安全:" Driver={SQL S...
    99+
    2024-04-02
  • Android 架构之数据库框架搭建
    目录1、先创建对应相关操作的注解1.1 bTable 标识表 1.2 DbPrimaryKey 标识主键 1.3 DbFiled 标识成员属性 2、创建对应表操作...
    99+
    2024-04-02
  • Android 架构之数据库框架升级
    目录1、备份原数据库File文件2、数据库升级XML编写 updateXml.xml3、创建XML解析器 3.1 对应工具类 DomUtils.class 3.2 对应XM...
    99+
    2024-04-02
  • 使用 PHP 函数库和框架的最佳实践?
    php 函数库和框架最佳实践:使用命名空间和 composer.json 声明依赖关系。选择适合您项目的框架(例如 laravel、slim、symfony)。遵循 psr 标准(例如 ...
    99+
    2024-05-02
    框架 php laravel redis composer
  • C#怎么使用ADO.Net连接数据库与实现多数据库访问
    本文小编为大家详细介绍“C#怎么使用ADO.Net连接数据库与实现多数据库访问”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#怎么使用ADO.Net连接数据库与实现多数据库访问”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作