新闻发布系统,SQLHelper重构

    在清楚把握牛腩新闻发布系统的需求,以及对系统的数据库也做好了相应的设计后,接下来的几天里就是对后台代码的编写。
    在视频中,采用的是经典三层的框架,这对于已经经历过机房重构的我们来说,敲代码还是很容易上手的。
    相信大家都不会忘记机房重构中我们的一个好助手,那就是SQLHelper。
    在机房重构的时候,看了很多博客,大家都用上了,也都觉得好用,我也就直接借鉴而来。在自己一步一步调试的时候,在自己的程序出现Bug的时候,真的发现SQLHelper的好处多多。但自己也没有去认真研究过这样一个类究竟是怎么写出来的。
     而现在学习的牛腩视频中,老师给我们清楚的讲解了SQLHelper是怎样一步一步进行完善的。这个过程,感觉真是受益匪浅。
    首先清楚对于数据库的操作,抽象后讲,也就是五步:连接——打开——执行——关闭——返回。
    在用面向对象C#语言编程中,构造函数就是用来进行初始化的工具。所以,连接数据库的代码为:
 public SQLHelper()
        {
            string connStr = "server=hzt-PC;database=newssystem;uid=sa;PWD=123456;";
        }
    下面是对连接状态做判断,如果为关闭,则将其打开:
 private SqlConnection GetConn()
        {
            if (conn.State == ConnectionState.Closed)
            {
                conn.Open();
            }
            return conn;
        }
    在数据库做完前两项工作后,便可以开始执行其他对于用户想执行的任何增删改查的操作。就拿一个执行无参数的查询的操作来说,代码如下:
public DataTable ExecuteQuery(string sql)
        {
            DataTable dt = new DataTable();
            //连接
            string connStr = "server=hzt-PC;database=newssystem;uid=sa;PWD=123456";
            SqlConnection conn = new SqlConnection(connStr);
            //打开
            conn.Open();
            //执行
            SqlCommand cmd = new SqlCommand(sql, conn);
            SqlDataReader sdr = cmd.ExecuteReader();
            dt.Load(sdr);
            //关闭
            sdr.Close();
            conn.Close();
            //返回
            return dt;
        }
       从上面的代码可以看到,每执行一个具体的操作,都还需要把连接-打开-关闭这三步的代码加上,我们便可对其进行封装,下面便开始对SQLHelper类进行重构。
     第一,从连接说起,在D层中写的代码是具体指明连接哪个数据库,连接哪个服务器,但如果我们想要更换一个数据库,那就必须跑到D层下修改之前编写好的代码,这是不符合开闭原则的。
     所以解决这一问题,我们加上配置文件,使连接的那一长串代码用一个字符串变量表示,如果更换数据库,只需要到配置文件中添加相应的代码就行。
     配置文件中代码:
<connectionStrings>
        <add name="connStr" connectionString="server=; database=newssystem;uid=sa;pwd=123456"/>
    </connectionStrings>
    数据库连接代码:
      public SQLHelper ()
        {
            string connStr = ConfigurationManager.ConnectionStrings["connStr"].ConnectionString;
            conn = new SqlConnection(connStr);
        }
    第二,仍旧是对数据库状态进行判断,这里没做什么改动。
    第三,对数据库进行各类操作,仍旧以一个执行无参数的查询操作为例,代码如下:
 public DataTable ExecuteQuery(string cmdText, CommandType ct)
        {
            DataTable dt = new DataTable();
            //执行
            cmd = new SqlCommand(cmdText, GetConn());
            cmd.CommandType = ct;
            //关闭
            using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
            {
                dt.Load(sdr);
            }
            //关闭
            return dt;
        }  
    从上面的代码来看,这就比第一次的SQLHelper简单了许多,其它类型的操作也像这样做,一个SQLHelper也就写好了。
    学习心得:
    这一次,对于SQLHelper类的重构的学习,使得自己对这个助手类又亲近了不少。在自己思考总结这个类是如何得来的这一个过程中,对之前学习的数据库的一些基本操作也回顾了一遍,感觉简单了不少。这一次的代码是照着视频中的源码写出来的,或许,下一次,自己根据总结的这五步,一步一步去写,也可以自己写出来一个完整的SQLHelper了。
时间: 2024-07-30 08:06:00

新闻发布系统,SQLHelper重构的相关文章

牛腩新闻发布系统(B/S)中的SQLHelper

1.关于SQLHelper的基础知识的说明,简单介绍一下: SqlHelper是一个基于.NET Framework的数据库操作组件.组件中包含数据库操作方法,SqlHelper有很多版本,主要以微软一开始发布的SqlHelper类,后面包含进了Enterprise Library开源包中了.还有一个主要版本是dbhelper.org开源的sqlhelper组件,优点是简洁,高性能,不仅仅支持sqlserver,同时支持sqlserver.oracle.access.Mysql数据库,也是一个开

新闻发布系统,B/S模式下的三层应用

三层的学习已接触四五个月了,最早是在学习VB.NET视频中开始接触的,那时候跟着视频敲了两个例子.再后来,个人机房重构的时候,从三层进步到了七层,此后就觉得我们不能仅仅局限于三层之上. 不过,那些都是C/S模式之下的编程.到现在,接触了B/S模式也一个多月了,第一个牛腩新闻发布系统觉得很是有趣,还是从最基本的开始,下面就一起看看B/S模式下,三层是怎样应用的.这篇博客就以添加新闻的实例来总结. 对于三层的整个过程大家都是很熟悉的了,那么在这里就不再赘述了,直接一层一层来分析. 一.思路整理. U

遇见你是一个秘密--牛腩新闻发布系统尾声

         遇见你是一个秘密          历经十三天的冬季美丽时光,牛腩新闻发布系统在距离平安夜还有一个月的日子里从尘埃里结出圣诞果,咋一听,牛腩老师的声音有一种小罗的赶脚,仔细一听,有一种唐欢师姐的味道,伴随着牛腩老师正宗的广西普通话的视频教学,让牛腩老师的每一节课都充满一种独具匠心的人格魅力.这种魅力会让小编没有困意,没有反感,吸引着小编跟着牛腩老师将所有问题一一解决,一直坚定的走到新闻发布的最后.            第一次接触B/S方面的知识,小心脏扑通扑通的跳,感觉到她对

点滴的积累---牛腩新闻发布系统总结

         最近学习状态一直都不错,最近敲完牛腩新闻发布系统后又看了看<培养计划6.0>发现"牛腩新闻发布系统"的作用其实就是一个成语--抛砖引玉.在该新闻发布系统中基本上涉及到了B/S开发所需要具备的知识模块(HTML.Asp.net.XML.JavaScript.CSS.DIV.JQuery.AJAX).通过这个小的系统我的学习也将从C/S转移到B/S上,当然这个小的系统带给我的远远不止这些.            一.重新认识了软件开发的流程.        

牛腩新闻发布系统--学习Web的小技巧汇总

        2014年11月10日,是个难忘的日子,这一天,小编的BS学习开始了,BS的开头,从牛腩新闻发布系统开始,之前学习的内容都是CS方面的知识,软考过后,开始学习BS,接触BS有几天的时间了,跟着牛腩老师敲着牛腩新闻发布系统,感觉棒棒哒,看了前面二十集,发现牛腩老师真的是把党的思想贯彻的淋漓尽致,跟着牛腩老师一起学习,发现了很多让我怦然心动的小知识,每次都让我的小宇宙爆发,现在就把这些小技巧分享给小编的小伙伴.该博文小编主要讲解三个方面的知识.第一:如何让代码整齐美观,第二:代码的注

【视频】 牛腩新闻发布系统

做了一个新闻发布系统,打算录制成视频,共享出来给大家看看评评,鸡蛋砖头请自备,欢迎来砸!     整个新闻发布系统的功能很简单,数据库增删查改而已,再配合一些杂七杂八的花哨...     具体的视频里再说,下面先早泄出一些界面图,以供大家欣赏!    整个视频录制打算分四部分来录制: 软件安装及数据库设计.文档编写 .NET三层后台代码编写 DIV+CSS前台界面设计(兼容IE6,7,8,firefox,opera,chrome) 后台代码与前台界面的整合及其他杂七杂八的花哨(ajax,jQue

用文本+ASP打造新闻发布系统(二)新闻添加

<!--#include file="news_session.asp"--><html><head> <meta http-equiv="Content-Language" content="zh-cn"><meta http-equiv="Content-Type" content="text/html; charset=gb2312"><

如何建立自己的新闻发布系统?

下面是一个建立新闻发布系统的程序,不用和数据库打交道哦步骤:(1).在vs2005中新建网站,新建三个aspx网页,分别命名:title.aspx,news.aspx,main.aspx其中title.aspx用来设置标题,可以自己设计,写几个字也行,news.aspx用来显示新闻标题,main.aspx用来显示新闻内容.(2).新建htm页,用来设计框架.代码如下:<html xmlns="http://www.w3.org/1999/xhtml" ><head&g

用文本+ASP打造新闻发布系统

//图片上传 <SCRIPT RUNAT=SERVER LANGUAGE=VBSCRIPT> Function GetUpload(FormData) Dim DataStart,DivStr,DivLen,DataSize,FormFieldData '分隔标志串(+CRLF) DivStr = LeftB(FormData,InStrB(FormData,str2bin(VbCrLf)) + 1) '分隔标志串长度 DivLen = LenB(DivStr) PosOpenBoundary