面向对象在数据库应用程序中的应用(dotNet)<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />
现在的应用程序很大一部分都是与数据库相关的程序,而写数据库程序会涉及到很多数据表,访问和操纵数据表构成了数据库应用程序最常见的动作,所以,编写出高效的程序对于程序员来说是不得不去考虑的。本文将讨论这个话题,希望对读者朋友有所裨益。
面向对象是当今程序界的普遍编程思想,他具有三个最基本的特征:封装、继承和多态。继承对于代码的复用非常有效,多态则是指函数(方法)的多种形态,可以通过子类重写父类的方法来改变对象的行为,在面向对象编程中起到非常重要的作用。那么,在实际应用中,到底能起到什么样的作用呢?也许使用例子最能表达这个思想。
比如,我们要写一个简单的论坛程序,经过分析,可以得出需要下面的表:用户表(Users)、版块表(BBSBlock)、回复表(Reply)、主题表(Topic)等(为了方便代码的继承,我把所有表的id号都设成相同的名称:id)。对于这些表,都有一些相同的操作:浏览,删除,添加和修改。那么,我们是不是对每个表都写对应的方法来实现呢?显示,这种方法是笨拙的。而继承,在这里就会发挥极为重要的作用。思想是:写一个父类,把这些基本的操作写好,然后,将每个表抽象成一个类,并继承刚才创建的父类,此时,所有的子类都具有这些基本操作了。
我们可以这样定义父类:
public class DBBaseClass
{
protected string TableName;//表名
protected SqlConnection con;//连接对象
public DBBaseClass():this("Users")
{
}
/// <summary>
/// 构造函数
/// </summary>
/// <param name="TableName">表名</param>
public DBBaseClass(string TableName)
{
this.TableName = TableName;
if(con == null)
{
con = new SqlConnection("server=accp-lzh;database=MissBBS;uid=sa;pwd=sa");
}
else
{
if(con.State == ConnectionState.Open)
con.Close();
}
}
/// <summary>
/// 获取数据集
/// </summary>
/// <param name="count">如果count为0,则获取所有数据集,否则获取指定条数(从顶部)的记录</param>
/// <returns>返回DataSet</returns>
public DataSet Select(int count)
{
string sql;
if(count == 0)
sql = "select * from " + this.TableName ;
else
sql = "select top " + count.ToString() + " * from " + this.TableName + " oreder by id desc";
SqlCommand selectCmd = new SqlCommand(sql,con);
SqlDataAdapter adapter = new SqlDataAdapter();
adapter.SelectCommand = selectCmd;
DataSet ds = new DataSet();
try
{
con.Open();
adapter.Fill(ds,"BBSTable");
con.Close();
}
catch(Exception)
{
return null;
}
return ds;
}
}
在这个类中,我们定义了两个重载的构造函数和一个用来获取数据集的方法,同时,定义了两个作用很大的字段,一个是表名,一个是连接对象。当其他类继承这个类时,就不再需要再次定义表和连接对象了,最主要是的,这两个字段为我们更好的实现继承起到了关键的作用。
接下来,我们创建一个子类:Users。这个类是表Users的抽象:
public class User : DBBaseClass
{
/// <summary>
/// 无参构造函数
/// </summary>
public User():base("Users")
{
}
/// <summary>
/// 构造函数
/// </summary>
/// <param name="TableName">表名</param>
public User(string TableName) : base(TableName)
{
}
}
现在,大家可以看出来,我们只是写了该类的两个构造函数,就具有返回表中所有数据集的功能了,因为该表继承了DBBaseClass。
同样,我们再写一个子类:Topic,该类是表Topic的抽象。
public class Topic : DBBaseClass
{
public Topic() : base("Topic")
{
}
public Topic(string TableName) : base(TableName)
{
}
}
和User一样,该类也同样具有了返回所有数据集的功能。
实例化子类时,采用简单对象工厂设计模式,返回不同类型的对象。
public class Factory
{
public Factory()
{
}
public static DBBaseClass GetObject(string TableName)
{
switch(TableName)
{
case "Users" :
return new User();
case "Topic":
return new Topic();
case "BBSBlock":
return new BBSBlock();
case "Reply":
return new Reply();
case "BBSMaster":
return new BBSMaster();
default:
return new DBBaseClass();
}
}
}
下面来看一看如何使用:
User user = (User)Factory.GetObject("Users");
DataSet ds1 = new DataSet();
ds1 = user.Select(0);
Topic topic = (Topic)Factory.GetObject("Topic");
DataSet ds2 = new DataSet();
ds2 = topic.Select(0);
看完之后,您有什么想法?如果您是一个经验丰富的程序员,这种方法肯定会经常采用,如果您刚刚接触,理解这种思想还是大有好处的。
分享到:
相关推荐
在 ASP.NET 2.0 中创建 Web 应用程序主题 ASP.NET 2.0 中的数据访问 ASP.NET 2.0:弃用 DataGrid 吧,有新的网格控件了! 将 ASP.NET 2.0 应用程序服务配置为使用 SQL Server 2000 或 SQL Server 2005 ASP.NET 2.0 ...
25.请详述在dotnet中类(class)与结构(struct)的异同? 答:Class可以被实例化,属于引用类型,是分配在内存的堆上的,Struct属于值类型,是分配在内存的栈上的. [Page] 26.根据委托(delegate)的知识,请完成以下用户...
9.1 面向对象编程的基本思想 440 9.2 类的继承 441 9.2.1 基类的概念 442 9.2.2 基类的派生类 442 9.3 继承机制下的访问控制 446 9.3.1 派生类中构造函数的操作 448 9.3.2 声明类的保护成员 452 ...
基于开发方法,开发人员可能会开始设计应用程序模型类,设计实际的数据库存储,然后在两者之间构建数据映射层。 每当出现新的更新时,它们就可能在这两个设计层之间来回移动。 但是,如果您可以跳过第二层和
通常模型对象负责在数据库中存取数据。 View(视图)是应用程序中处理数据显示的部分。 通常视图是依据模型数据创建的。 Controller(控制器)是应用程序中处理用户交互的部分。 通常控制器负责从视图读取数据,...
Moranbernate是面向.Net应用程序的轻量级,高性能,高吞吐量的ORM,可为大规模应用程序提供简单而强大的数据访问。 强调 为实现高性能而设计,同时考虑了规模和吞吐量 用于CRUD查询的批量操作,可以在进行数据操作时...
您可以在MVC,Web API,控制台应用程序中使用FastReport开源。 产品特点 FastReport用C#编写,并且与.NET Standard 2.0和更高版本兼容。 可扩展的FastReport体系结构允许创建您自己的对象,导出过滤器,向导和...
1.Web安全性的考虑(表单验证、浏览器Basic方式的验证,应用程序的安全性,SSL,代码考虑) 2.简单介绍您所了解的MVC。 3.简单介绍所了解的XML。 4.文档和编码规范 5.Java中的分页、效率考虑。 6.简单介绍您所...
简介:KLMap是国人基于C#写的一个小型的GIS应用程序项目,这个项目实现了GIS中空间数据浏览,查询和编辑以及最短路径等功能。该项目包括源代码,样例数据。 特点: 不同于当前业界常规的GIS应用需要依托第三方的GIS...