您的位置:软件 > 开发者网络 > 微软开发专栏 > Visual Studio.net专栏 > C# > 正文
使用设计模式构建通用数据库访问类
[文章信息]
作者:sunny_y_m
时间:2004-05-18
出处:论坛
责任编辑:方舟
[文章导读]
数据库的访问是非常重要的,我们通常需要将对数据库的访问集中起来,以保证良好的封装性和可维护性
advertisement
热点推荐
· 天极网软件频道改版调查
· 10.26精选 图画:葡萄小鸡图
· Windows操作系统网络管理技巧
· Fireworks国画:葡萄小鸡图
· 黑客张大民江南小城奇遇记
[正文]
天极IT资讯短信服务 电脑小技巧
资费:包月5元
手机:
介绍:细处着手,巧处用功。高手和菜鸟之间的差别就是:高手什么都知道,菜鸟知道一些。电脑小技巧收集最新奇招高招,让你轻松踏上高手之路。

  在应用程序的设计中,数据库的访问是非常重要的,我们通常需要将对数据库的访问集中起来,以保证良好的封装性和可维护性。在.Net中,数据库的访问,对于微软自家的SqlServer和其他数据库(支持OleDb),采用不同的访问方法,这些类分别分布于System.Data.SqlClient和System.Data.OleDb名称空间中。微软后来又推出了专门用于访问Oracle数据库的类库。
看图之王ACDSee 6.0应用大全 数码人像照片矢量化及艺术处理
六天学会Visual Basic数据库编程 解析“震荡波”恶性蠕虫病毒
我们希望在编写应用系统的时候,不因这么多类的不同而受到影响,能够尽量做到数据库无关,当后台数据库发生变更的时候,不需要更改客户端的代码。

  这就需要我们在实际开发过程中将这些数据库访问类再作一次封装。经过这样的封装,不仅可以达到上述的目标,还可以减少操作数据库的步骤,减少代码编写量。在这个方面,微软为我们提供了Application Block,但是,可惜的是目前只支持Sql Server。这里,介绍一种在实际应用中得到了非常好的效果的实作策略——笔者编写的Websharp框架中的数据访问结构。Factory设计模式是使用的主要方法。

  我们先来看看Factory的含义:定义一个用于创建对象的接口,让子类决定实例化哪一个类。Factory Method使一个类的实例化延迟到其子类。我们这里可能会处理对多种数据库的操作,因此,需要首先定义一个操纵数据库的接口,然后,根据数据库的不同,由类工厂决定实例化哪个类。

  下面,我们首先来定义这个访问接口。为了方便说明问题,我们在这里只列出了比较少的方法,其他的方法是很容易参照添加的。

public interface DataAccess
{
 DatabaseType DatabaseType{get;} //数据库类型
 IDbConnection DbConnection{get;} //得到数据库连接
 void Open(); //打开数据库连接
 void Close(); //关闭数据库连接

 IDbTransaction BeginTransaction(); //开始一个事务
 int ExecuteNonQuery(string commandText); //执行Sql语句
 DataSet ExecuteDataset(string commandText);//执行Sql,返回DataSet
}

  因为,DataAccess的具体实现类有一些共同的方法,所以,先从DataAccess实现一个抽象的AbstractDataAccess类,包含一些公用方法。然后,我们分别为Sql Server、Oracle和OleDb数据库编写三个数据访问的具体实现类:

public sealed class MSSqlDataAccess : AbstractDataAccess
{
 ……//具体实现代码。
}

public class OleDbDataAccess : AbstractDataAccess
{
 ……//具体实现代码。
}

public class OracleDataAccess : AbstractDataAccess
{
 ……//具体实现代码。
}

  现在我们已经完成了所要的功能,下面,我们需要创建一个Factory类,来实现自动数据库切换的管理。这个类很简单,主要的功能就是根据数据库类型,返回适当的数据库操纵类。

public sealed class DataAccessFactory
{
 private DataAccessFactory(){}
 private static PersistenceProperty defaultPersistenceProperty;
 public static PersistenceProperty DefaultPersistenceProperty
 {
  get{return defaultPersistenceProperty;}
  set{defaultPersistenceProperty=value;}
 }

public static DataAccess CreateDataAccess(PersistenceProperty pp)
{
 DataAccess dataAccess;
 switch(pp.DatabaseType)
 {
  case(DatabaseType.MSSQLServer):
   dataAccess = new MSSqlDataAccess(pp.ConnectionString);
   break;
  case(DatabaseType.Oracle):
   dataAccess = new OracleDataAccess(pp.ConnectionString);
   break;
  case(DatabaseType.OleDBSupported):
   dataAccess = new OleDbDataAccess(pp.ConnectionString);
   break;
  default:
   dataAccess=new MSSqlDataAccess(pp.ConnectionString);
   break;
 }
 return dataAccess;
}

public static DataAccess CreateDataAccess()
{
 return CreateDataAccess(defaultPersistenceProperty);
}

}

  好了,现在,一切都完成了,客户端在代码调用的时候,可能就是采用如下形式:

PersistenceProperty pp = new PersistenceProperty();
pp.ConnectionString = "server=127.0.0.1;uid=sa;pwd=;database=Northwind;";
pp.DatabaseType = DatabaseType. MSSQLServer;
pp.UserID = “sa”;
pp.Password = “”;
DataAccess db= DataAccessFactory.CreateDataAccess(pp)
db.Open();
……//db.需要的操作
db.Close();

  或者,如果事先设定了DataAccessFactory的DefaultPersistenceProperty属性,可以直接使用
DataAccess db= DataAccessFactory.CreateDataAccess()方法创建DataAccess实例。

  当数据库发生变化的时候,只需要修改PersistenceProperty的值,客户端不会感觉到变化,也不用去关心。这样,实现了良好的封装性。当然,前提是,你在编写程序的时候,没有用到特定数据库的特性,例如,Sql Server的专用函数。

  以上,介绍了一种通用数据库操作类的实现设计方法,希望能够对大家有所启发。

·"WAP天极之IT新闻资讯,50万元等你拿"    ·天极WAP之游戏狂图,50万元等你下载

天极社区邀请您:写博客日记  上传相片   论坛聊天  订阅电子杂志  推荐网摘   免费图铃工具
笔名:   请您注意:

 遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。

 天极网拥有管理笔名和留言的一切权利。
评论:
 

发表评论推荐给朋友我想参加相关培训打印我对此感兴趣订阅电子杂志
相关内容阅读排行榜
  • 设计带图标和自定义颜色的ListBox
  • 用C#设计在局域网发送短信的程序
  • 浅析.NET开发中代理模式的使用
  • C#抽象工厂模式的几种实现方法及比较
  • 使用Visual C#实现断点续传
  • 改善电视卡接收效果三个诀窍
  • 液晶该不该使用屏保等问答6则
  • 自力更生维修4.1音箱实例
  • 发烧大餐 六千元游戏配置
  • 10.26精选 图画:葡萄小鸡图
  • 网络打印服务器选购攻略
  • 信不信集成显卡BIOS我也照刷
  • 李鬼哪里逃 处理器假货曝光
  • Advertisement

    天极无线
    待机彩图    >>更多
    多彩动画    >>更多
    美妙和弦    >>更多
    天使在唱歌
    壁虎漫步
    PrettyBoy
    LoveLoveLove
    我是你的小小狗
    单身情歌
    十面埋伏
    祝酒歌
    回心转意
    波斯猫
    太委屈
    S.H.E
    潘玮柏
    M2M
    蔡依林
    阿牛
    林志炫
    陈弈迅
    刀郎
    黑龙
    S.H.E
    陶晶莹
    情人玫瑰坊
    音乐风云
    新片速递
    神秘测试
    都市约会
    ·天极彩信天天精彩
    ·图铃梦工厂下载无限!
    ·找寻童真,卡通专题
    ·夏日激情交友社区!
    ·星座运程,预测人生

    CSEEK搜索