0

0

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

php中文网

php中文网

发布时间:2016-06-07 15:36:04

|

1425人浏览过

|

来源于php中文网

原创

面向对象在数据库应用程序中的应用 (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

    {

        ///

        /// 无参构造函数

极限网络办公Office Automation
极限网络办公Office Automation

专为中小型企业定制的网络办公软件,富有竞争力的十大特性: 1、独创 web服务器、数据库和应用程序全部自动傻瓜安装,建立企业信息中枢 只需3分钟。 2、客户机无需安装专用软件,使用浏览器即可实现全球办公。 3、集成Internet邮件管理组件,提供web方式的远程邮件服务。 4、集成语音会议组件,节省长途话费开支。 5、集成手机短信组件,重要信息可直接发送到员工手机。 6、集成网络硬

下载

        ///

        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

相关专题

更多
苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

115

2025.12.24

拼豆图纸在线生成器
拼豆图纸在线生成器

拼豆图纸生成器有PixelBeads在线版、BeadGen和“豆图快转”;推荐通过pixelbeads.online或搜索“beadgen free online”直达官网,避开需注册的诱导页面。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

82

2025.12.24

俄罗斯搜索引擎yandex官方入口地址(最新版)
俄罗斯搜索引擎yandex官方入口地址(最新版)

Yandex官方入口网址是https://yandex.com。用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

546

2025.12.24

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

150

2025.12.24

php框架基础知识汇总
php框架基础知识汇总

php框架是构建web应用程序的架构,提供工具和功能,以简化开发过程。选择合适的框架取决于项目需求和技能水平。实战案例展示了使用laravel构建博客的步骤,包括安装、创建模型、定义路由、编写控制器和呈现视图。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

20

2025.12.24

Word 字间距调整方法汇总
Word 字间距调整方法汇总

本专题整合了Word字间距调整方法,阅读下面的文章了解更详细操作。

47

2025.12.24

任务管理器教程
任务管理器教程

本专题整合了任务管理器相关教程,阅读下面的文章了解更多详细操作。

7

2025.12.24

AppleID格式
AppleID格式

本专题整合了AppleID相关内容,阅读专题下面的文章了解更多详细教程。

12

2025.12.24

csgo视频观看入口合集
csgo视频观看入口合集

本专题整合了csgo观看入口合集,阅读下面的文章了知道更多入口地址。

371

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4万人学习

Vue 教程
Vue 教程

共42课时 | 5.4万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号