面向对象在数据库应用程序中的应用(dotNet)
2024-07-21 02:23:22
供稿:网友
面向对象在数据库应用程序中的应用(dotnet)
现在的应用程序很大一部分都是与数据库相关的程序,而写数据库程序会涉及到很多数据表,访问和操纵数据表构成了数据库应用程序最常见的动作,所以,编写出高效的程序对于程序员来说是不得不去考虑的。本文将讨论这个话题,希望对读者朋友有所裨益。
面向对象是当今程序界的普遍编程思想,他具有三个最基本的特征:封装、继承和多态。继承对于代码的复用非常有效,多态则是指函数(方法)的多种形态,可以通过子类重写父类的方法来改变对象的行为,在面向对象编程中起到非常重要的作用。那么,在实际应用中,到底能起到什么样的作用呢?也许使用例子最能表达这个思想。
比如,我们要写一个简单的论坛程序,经过分析,可以得出需要下面的表:用户表(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);
看完之后,您有什么想法?如果您是一个经验丰富的程序员,这种方法肯定会经常采用,如果您刚刚接触,理解这种思想还是大有好处的。