问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

面向对象数据库的其他应用

发布网友 发布时间:2022-05-03 23:03

我来回答

2个回答

懂视网 时间:2022-05-04 03:24

面向对象在数据库应用程序中的应用 (dotNet) 现在的应用程序很大一部分都是与数据库相关的程序,而写数据库程序会涉及到很多数据表,访问和操纵数据表构成了数据库应用程序最常见的动作,所以,编写出高效的程序对于程序员来说是不得不去考虑的。本文将讨论

面向对象在数据库应用程序中的应用(dotNet)

现在的应用程序很大一部分都是与数据库相关的程序,而写数据库程序会涉及到很多数据表,访问和操纵数据表构成了数据库应用程序最常见的动作,所以,编写出高效的程序对于程序员来说是不得不去考虑的。本文将讨论这个话题,希望对读者朋友有所裨益。

面向对象是当今程序界的普遍编程思想,他具有三个最基本的特征:封装、继承和多态。继承对于代码的复用非常有效,多态则是指函数(方法)的多种形态,可以通过子类重写父类的方法来改变对象的行为,在面向对象编程中起到非常重要的作用。那么,在实际应用中,到底能起到什么样的作用呢?也许使用例子最能表达这个思想。

比如,我们要写一个简单的论坛程序,经过分析,可以得出需要下面的表:用户表(Users)、版块表(BBSBlock)、回复表(Reply)、主题表(Topic)等(为了方便代码的继承,我把所有表的id号都设成相同的名称:id)。对于这些表,都有一些相同的操作:浏览,删除,添加和修改。那么,我们是不是对每个表都写对应的方法来实现呢?显示,这种方法是笨拙的。而继承,在这里就会发挥极为重要的作用。思想是:写一个父类,把这些基本的操作写好,然后,将每个表抽象成一个类,并继承刚才创建的父类,此时,所有的子类都具有这些基本操作了。

我们可以这样定义父类:

public class DBBaseClass

{

protected string TableName;//表名

protected SqlConnection con;//连接对象

public DBBaseClass():this("Users")

{

}

///

/// 构造函数

///

/// 表名

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();

}

}

///

/// 获取数据集

///

/// 如果count为0,则获取所有数据集,否则获取指定条数(从顶部)的记录

/// 返回DataSet

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

{

///

/// 无参构造函数

///

public User():base("Users")

{

}

///

/// 构造函数

///

/// 表名

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);

看完之后,您有什么想法?如果您是一个经验丰富的程序员,这种方法肯定会经常采用,如果您刚刚接触,理解这种思想还是大有好处的。

posted on 2004年08月19日 3:28 PM

热心网友 时间:2022-05-04 00:32

还有许多应用要求多媒体数据库。它们要求以集成方式和文本或图形信息一起处理关系数据,这些应用包括高级办公室系统的其它文档管理系统。
人工智能(AI)应用的需要,如专家系统,也推动了面向对象数据库的发展。专家系统常需要处理各种(通常是复杂的)数据类型。与关系数据库不同,面向对象数据库不因数据类型的增加而降低处理效率。
由于这些应用需求,80年代已开始出现一些面向对象数据库的商品和许多正在研究的面向对象数据库。多数这样的面向对象数据库被用于基本设计的学科和工程应用领域。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
说课包括哪些方面 说课内容包括()。 如何在手机百度上删除对话记录? 结核病是什么样的疾病? 曹丕17岁得了肺痨,明知自己命不长久,还要强争王位,是不是很自私呢?_百... 古代小说常出现的病名 急求一篇"生活小窍门"(500字)的作文 至今最有什么小妙招 健康的戒烟方法 笔记本电池锁死是什么原因引起的? 大数据应用价值发现的三大方法 基于大数据的学习分析技术研究怎么检索 哪里有JavaFx技术课程 javafx怎么连接数据库使javafx的界面实现增删查改,和显示出数据库的数据啊,求大佬 JavaFX+scenebuilder2.0怎么连接数据库实现登录? 如何用Javafx查看Derb数据库中表的内容 javafx如何使数据库的内容显示在TableView中? 什么时候该用NoSQL JBoss Web和Tomcat的区别 1)运用"重构-重命名”:修改数组a的名称; 好难,我不会。。。。。 ; 色彩重构和采集的方法 什么是代码重构? 覆盖(重写),重构,重载的区别和这到底是否重载 求打散重构的图片 如何成为一个程序老手,新手必知的40个小技巧 如何重构一个完全陌生的项目 空间重构题目怎么提高正确率 求机战能快速重构完成的方法.100分悬赏 整体重构方法 怎样使用搜索引擎 什么是.Net面向对象? 面向对象中如何实现对话框与数据库的链接? 面向对象数据库的另一进展 面向对象数据库的优点 c# 面向对象的数据库有哪些 面向对象数据库有哪些 面向对象数据库系统的存在的问题 大家知道面向对象技术在系统集成中的应用是什么吗? 要做面向对象数据库,从哪里入手 什么叫做“面向对象”数据库? 请问数据库对面向对象的语言有用么?``` magento关于block的问题 magento怎么在我的页面显示产品 如何安装Magento模板 清除Magento缓存的几种方法 在magento中我想要在产品详细页面输出特定分类的产品(推荐产品),具体的请看问题补充。 magento前台页面的链接如何设置跳转? magento Developer debug 怎么用 magento模板中Block的type值的定义与意义,谁能详解下? magento 页怎么调用css?