使用Spring.net中对Ado.net的抽象封装来访问数据库
使用Spring.net中对Ado.net的抽象封装来访问数据库
Spring.NET是一个应用程序框架,其目的是协助开发人员创建企业级的.NET应用程序。它提供了很多方面的功能,比如依赖注入、面向方面编程(AOP)、数据访问抽象及ASP.NET扩展等等。Spring.NET以Java版的Spring框架为基础,将Spring.Java的核心概念与思想移植到了.NET平台上。
要采用spring.net的数据访问抽象来访问sql server数据库,首先要引用spring.net的相应程序集spring.core,spring.data,common.Logging等,从 AdoDaoSupport 派生一个用于数据访问的类,然后项目的配置文件app.config中要添加相应的配置,然后就可以访问数据库了。
1.从 AdoDaoSupport 派生一个用于数据访问的类AdoDaoBase.cs
- namespace AdoNetAccess
- {
- public class AdoDaoBase:AdoDaoSupport
- {
- private string cmdText = @"select Address, City, CompanyName, ContactName, " +
- "ContactTitle, Country, Fax, CustomerID, Phone, PostalCode, " +
- "Region from Customers ";
- public DataTable GetCustomer()
- {
- return AdoTemplate.DataTableCreate(CommandType.Text, cmdText);
- }
- }
- }
2.app.config要添加如下的配置:
- <?xml version="1.0" encoding="utf-8" ?>
- <configuration>
- <configSections>
- <sectionGroup name="common">
- <section name="logging" type="Common.Logging.ConfigurationSectionHandler, Common.Logging"/>
- </sectionGroup>
- <sectionGroup name="spring">
- <section name="parsers" type="Spring.Context.Support.NamespaceParsersSectionHandler, Spring.Core"/>
- <section name="context" type="Spring.Context.Support.ContextHandler, Spring.Core"/>
- <section name="objects" type="Spring.Context.Support.DefaultSectionHandler, Spring.Core"/>
- </sectionGroup>
- <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
- </configSections>
- <common>
- <logging>
- <factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4Net">
- <arg key="configType" value="INLINE"/>
- </factoryAdapter>
- </logging>
- </common>
- <log4net>
- <appender name="FileAppender" type="log4net.Appender.FileAppender">
- <file type="log4net.Util.PatternString" value="Logs\%date{yyyMMdd}.log"/>
- <appendToFile value="true"/>
- <layout type="log4net.Layout.PatternLayout">
- <conversionPattern value="%date %-5level - %message%newline"/>
- </layout>
- </appender>
- <root>
- <level value="INFO"/>
- <appender-ref ref="FileAppender"/>
- </root>
- <logger name="Spring">
- <level value="WARN"/>
- </logger>
- <logger name="Clubank">
- <level value="DEBUG"/>
- </logger>
- </log4net>
- <spring>
- <parsers>
- <parser type="Spring.Data.Config.DatabaseNamespaceParser, Spring.Data"/>
- </parsers>
- <context>
- <resource uri="config://spring/objects"/>
- </context>
- <objects xmlns="http://www.springframework.net" xmlns:db="http://www.springframework.net/database" xmlns:tx="http://www.springframework.net/tx">
- <db:provider id="dbProvider" provider="System.Data.SqlClient" connectionString="Data Source=.\SQLEXPRESS2005;Initial Catalog=Northwind;Persist Security Info=True;User ID=sa;Password=1234;Trusted_Connection=False"/>
- <object id="adoTemplate" type="Spring.Data.Core.AdoTemplate, Spring.Data">
- <property name="DbProvider" ref="dbProvider"/>
- </object>
- <!-- 查询定义 -->
- <object id="AdoDaoBase" type="AdoNetAccess.AdoDaoBase, AdoNetAccess">
- <!-- 注入 AdoTemplate -->
- <property name="AdoTemplate" ref="adoTemplate"/>
- </object>
- </objects>
- </spring>
- </configuration>
3.测试访问数据库,Program.cs中的代码:
- using System;
- using System.Collections.Generic;
- using System.Data;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- namespace AdoNetAccess
- {
- class Program
- {
- static void Main(string[] args)
- {
- Spring.Context.IApplicationContext context = Spring.Context.Support.ContextRegistry.GetContext();
- Spring.Data.Common.IDbProvider provider = context.GetObject("dbProvider") as Spring.Data.Common.IDbProvider;
- Spring.Data.Core.AdoTemplate adoTemplate = context.GetObject("adoTemplate") as Spring.Data.Core.AdoTemplate;
- object result = adoTemplate.ExecuteScalar(System.Data.CommandType.Text, "select count(*) from Customers");
- AdoDaoBase dao = context.GetObject("AdoDaoBase") as AdoDaoBase;
- DataTable dt = dao.GetCustomer();
- Console.WriteLine();
- }
- }
- }
上面是一个简单的示例,参考了很多的文章,有:
- http://www.cnblogs.com/haogj/archive/2011/06/13/2079928.html
- http://www.cnblogs.com/haogj/archive/2011/06/18/2084065.html
- http://www.cnblogs.com/GoodHelper/archive/2009/11/20/SpringNet_blogs.html
- http://www.cnblogs.com/heartstill/archive/2011/08/25/2153832.html
- http://www.cnblogs.com/GoodHelper/archive/2009/11/20/SpringNet_Index.html
- http://www.cnblogs.com/MyNameEPC/archive/2009/05/09/1453409.html
谢谢以上博客的博主。
代码下载: SpringNET.rar
使用Spring.net中对Ado.net的抽象封装来访问数据库的更多相关文章
- Spring.NET 中的 ADO.NET 数据访问的示例
Spring.NET 1.3.1 中提供了一个使用 AdoTemplate 的完整示例,包括使用泛型和使用非泛型技术进行数据访问,这个示例位于下载的压缩包中\Spring.NET-1.3.1\Spri ...
- 在Golang中如何正确地使用database/sql包访问数据库
本文记录了我在实际工作中关于数据库操作上一些小经验,也是新手入门golang时我认为一定会碰到问题,没有什么高大上的东西,所以希望能抛砖引玉,也算是对这个问题的一次总结. 其实我也是一个新手,机缘巧合 ...
- Spring Boot中使用时序数据库InfluxDB
除了最常用的关系数据库和缓存之外,之前我们已经介绍了在Spring Boot中如何配置和使用MongoDB.LDAP这些存储的案例.接下来,我们继续介绍另一种特殊的数据库:时序数据库InfluxDB在 ...
- Spring.NET中事务管理【转】
http://www.cnblogs.com/GoodHelper/archive/2009/11/16/springnet_transaction.html 浏览了下写的比较清楚. 在.NET FC ...
- spring boot(三):Spring Boot中Redis的使用
spring boot对常用的数据库支持外,对nosql 数据库也进行了封装自动化. redis介绍 Redis是目前业界使用最广泛的内存数据存储.相比memcached,Redis支持更丰富的数据结 ...
- Spring Boot中的事务管理
原文 http://blog.didispace.com/springboottransactional/ 什么是事务? 我们在开发企业应用时,对于业务人员的一个操作实际是对数据读写的多步操作的结合 ...
- Spring mvc中@RequestMapping 6个基本用法
Spring mvc中@RequestMapping 6个基本用法 spring mvc中的@RequestMapping的用法. 1)最基本的,方法级别上应用,例如: Java代码 @Reques ...
- 如何动态在spring mvc中增加bean
阅读对象 搭框架人员,或者其他感兴趣的开发人员 背景 一般来说在业务代码中,加上 @Component, @Service,@Repository, @Controller等注解就可以实现将bean注 ...
- Spring Boot中的注解
文章来源:http://www.tuicool.com/articles/bQnMra 在Spring Boot中几乎可以完全弃用xml配置文件,本文的主题是分析常用的注解. Spring最开始是为了 ...
随机推荐
- Objective-C之@class的使用
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- 小波说雨燕 第三季 构建 swift UI 之 UI组件集-视图集(二)ActionSheet视图 学习笔记
action动作 sheet表 其实就是一种菜单 参数:1代理:谁去代理它2取消按钮标题3这个按钮标题会自动变成红色4添加设置其他按钮(不想加,设置为nil) 然后我们为这些按钮添加点击事件: ...
- LeetCode 1 Two Sum(二分法)
题目来源:https://leetcode.com/problems/two-sum/ Given an array of integers, find two numbers such that t ...
- 快捷下载 sourceForge下的资源
一些开源项目通常会放在 sourceforge.net下面发布.然而,这个网站有时候出现卡顿,并且需要点击几次页面才能下载到自己想要的资源. 这里有个好办法,一步列出所有可下载的资源: ...
- 这些git技能够你用一年了
用git有一年了,下面是我这一年来的git使用总结,覆盖了日常使用中绝大多数的场景.嗯,至少是够用一年了,整理出来分享给大家,不明白的地方可以回复交流. git设置关闭自动换行 git config ...
- 测试管理_出色测试管理者的思考[持续更新ing]
如何合理安排并按质按量按时完成每一个测试任务,做好项目管理? 如何把控到每一个测试任务的质量? 如何快速构建和构建好测试环境? 如何获取或快速制作测试数据? 如何确保每一个测试人员的工作都饱满? 如何 ...
- python操作db2和mysql ,ibm_db
我需要提取mysql和db2的数据进行对比,所以需要用python对其都进行操作. python对mysql进行操作应该没什么问题,就是安装drive后就可以了,在上一篇中有讲安装python-mys ...
- 《HeadFirst设计模式》读后感——对学习设计模式的一些想法
最近看完了<HeadFirst设计模式>,GOF的<设计模式——可复用面向对象软件的基础>的创建型模式也读完了,经历了从一无所知到茅塞顿开再到充满迷惑的过程. 不得不说< ...
- 设计模式C#实现(六)——单例模式
单例模式:保证一个类仅有一个实例,并提供一个访问它的全局访问点. 构成: 1.私有的构造函数 2.私有静态的实例 3.返回实例的静态方法 public class Singleton { privat ...
- HTML5 datalist 标签
以前需要用JS写一个自动完成组件(Suggest),很费劲.HTML5时代则不用了,直接使用datalist标签,直接减少了工作量.如下 <!DOCTYPE html> <html& ...