本文为您介绍了DB2 9.0+提供的ADO.NET Provider,ADO.NET Provider支持.NET 2.0,方面了使用DB2作数据访问。如果您对此有兴趣,不妨一看,会对您有所帮助。
虽然很多朋友都在用.NET作数据访问,但使用DB2的应该不多,偶尔使用也是用ODBC或OLE DB方式。
DB2 9.0+提供了支持.NET 2.0的ADO.NET Provider, 尤其对于使用PureXML开发XQuery的朋友而言,这个功能上要比OLE DB,ODBC的方式丰富。
我安装的是DB2 9.5 Express-C版本
开发环境是VS 2008,不过其实用VS 2005的DB 9.5 Visual Studio 2005 Add-ins更方便
基于代码的访问就不提了,这里介绍一个App.Config的方式 (google了一下,找不到合适的,经过误打误撞碰出了providerName="IBM.Data.DB2")
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Diagnostics;
using System.Data.Common;
using System.Configuration;
namespace MarvellousXml.Library.Data
{
///
/// 完成数据操作的抽象基类
///
public class Database
{
protected string name;
ConnectionStringSettings setting;
public Database(string name)
{
this.name = name;
this.setting = ConfigurationManager.ConnectionStrings[name];#p#
}
///
/// 提供DbConnection实例
///
///
public DbConnection GetConnection()
{
return CreateConnection(this.name);
}
#region Helper Methods
///
/// 根据配置构造DbConnection实例
///
///
///
private DbConnection CreateConnection(string name)
{
if (string.IsNullOrEmpty(name))
throw new ArgumentNullException("name");
DbProviderFactory factory = DbProviderFactories.GetFactory(setting.ProviderName);
DbConnection connection = factory.CreateConnection();
connection.ConnectionString = setting.ConnectionString;
return connection;
}
#endregion
}#p#
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using System.Data;
using System.Data.Common;
using MarvellousXml.Library.Data;
namespace MarvellousXml.Library.Data.Test
{
[TestClass]
public class DatabaseFixture
{
[TestMethod]
public void CreateDb2Database()
{
string dbName = "DB2.Test";
Database database = DatabaseFactory.Create(dbName);
Assert.IsNotNull(database);
DbConnection connection = database.GetConnection();
connection.Open();
Assert.IsTrue(connection.State == ConnectionState.Open);
}
}
}#p#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
namespace MarvellousXml.Library.Data
{
///
/// 构造Database的工厂类型 (还没有完成的 毛坯)
///
public static class DatabaseFactory
{
///
/// 构造
///
/// 逻辑连接名称
///
public static Database Create(string name)
{
return new Database(name);
}
}
}
本文标题:DB29.0+提供支持.NET2.0的ADO.NETProvider
转载来源:http://www.csdahua.cn/qtweb/news21/329671.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网