Step By Step 一步一步写网站[1] —— 填加数据(二)

简介: (这个是我认真思考并精心写的,能不能算作高质量我就不敢说了)建议先看一下第一篇:http://www.cnblogs.com/jyk/archive/2007/03/23/685075.html 上一篇写了我常用的方法,这里想说一下我猜想的OOD的方法,之所以用猜想,是因为我没有用过OOD的方法,我也不知道我这么写对不对,所以用了“猜想”二字。

(这个是我认真思考并精心写的,能不能算作高质量我就不敢说了img_ee31f4a71dc14bc13f6edeac6dd60bbc.gif

建议先看一下第一篇:
http://www.cnblogs.com/jyk/archive/2007/03/23/685075.html

上一篇写了我常用的方法,这里想说一下我猜想的OOD的方法,之所以用猜想,是因为我没有用过OOD的方法,我也不知道我这么写对不对,所以用了“猜想”二字。

.aspx文件。和上一篇的应该没有什么区别。

代码:.aspx.cs文件,给属性赋值。

public   void  add3()
        
... {
            添加信息 信息 
= new 添加信息();
            信息.标题 
= this.Txt_Title.TextTrimNone;
            信息.作者 
= this.Txt_Editor.TextTrimNone;    //作者;
            信息.内容 = this.Txt_Content.TextTrimNone;    //内容;
            信息.保存();
           
        }

 代码:.cs文件(放在.aspx.cs里面也可以吧),“添加信息”类的实现。

public   class  添加信息
    
... {
        
private string _标题 = "";
        
private string _作者 = "";
        
private string _内容 = "";
        
        
public string 标题
        
...{
            
set...{_标题 = value;}
            
get...{return _标题;}
        }

        
public string 作者
        
...{
            
set...{_作者 = value;}
            
get...{return _作者;}
        }

        
public string 内容
        
...{
            
set...{_内容 = value;}
            
get...{return _内容;}
        }


        
public bool 保存()
        
...{
            System.Data.SqlClient.SqlConnection cn 
= new System.Data.SqlClient.SqlConnection();
            
//......
            return true;
        }


    }

保存()方法的实现代码就省略了,实现方式太多了,
可以使用SqlConnection,SqlCommand等来添加;
可以调用SQLHelp来添加,可以组合SQL语句,也可以使用存储过程;
还可以调用数据访问层(这样就变成三层的方式了吧)。

这是我感觉上的OOD,也不知道对不对。不对的话请及时指正,以免误导大家!

 注:这里的类使用了中文,一是从来没有用过中文的变量、类名,这次想试一试;二是感觉中文的好像能更好理解一下吧。


 

再猜一下三层的方法。

UI层:绘制控件,应该也是一样的。然后给实体类赋值。

逻辑层:......

数据层:组合SQL语句(或者给存储过程的参数赋值),然后调用SQLHelp保存数据(或者使用SqlCommand等对象保存数据)。

什么?你问逻辑层怎么写了一堆点呀。是呀,猜不出来这里要写什么,我也不瞎猜了,免得挨板砖:)。

另外两层写的也不知道对不对,不对的话请及时指正。

 

总结:

三个方法,用了两个帖子表达了一下。下面横向对比一下。

1、需求发生变化。(增加功能)

一开始文章不多,不需要分类,现在文章多了要分一下类。显然要加一个字段(另一个说法:实体类加一个属性)来保存分类信息。我们来看看这三个方法都需要改那些地方。

.aspx里面的修改都是一样的,加一个下拉列表框显示信息的分类,让用户来选择。

.aspx.cs 、.cs

我的方法:str1 数组加一个元数{a},来保存分类字段的名称,str 数组也加一个元数{b},来保存用户选择的分类。需要验证的话再加一个验证。

OOD的方法:add3() 里面增加一行赋值的代码{b};“添加信息”类里面加一个属性{a};保存() 方法里面作适当的修改{c}

三层的方法:实体类加一个属性{b};赋值的地方加一行代码{a};数据层组合SQL语句(或者给存储过程的参数赋值)需要修改,然后调用SQLHelp保存数据(或者使用SqlCommand等对象保存数据)还是需要修改{c}

最后是逻辑层,由于猜不出来写些什么,所以也不知道需不需要修改。

添加一个字段的时候,我的方法只需要{a}、{b}两个修改,而另两个还需要{c}的修改。三层中可能还要修改一下逻辑层。

{a}、{b}、{c}三处需要修改的代码量大家都清楚吧,我就不多说了。

2、表名字段名需要修改。

这个应该是不常发生的,顺便说一下吧。

表名、字段名,在我的方法里面分别只出现了一次,修改一个地方就可以了。

另两个方法呢,组合SQL语句(或者存储过程)需要修改,至于属性(实体类)要不要修改我就不知道了。如果属性(实体类)修改了,那么赋值的地方也需要修改,验证的地方也需要修改。

3、更换数据库。

这个是三层拿手的吧(便于应对的吧)。我们看看需要修改那些地方。

我的方法,更换一个“我的数据访问层”。“我的数据访问层”是通用的,每一种数据库都有一个专用的“我的数据访问层”与之对应。换数据库换一个dll文件基本就可以了。

三层呢?需要改一下数据层的代码。

 实际中我只经历了一次更换数据库的情况,换了一个DLL文件,由于Access和MS SQL的SQL的标准不太一样,又修改了一些不太“兼容”的SQL语句。代码(C#)上基本没有什么修改。

至于访问层嘛,也只是把 SqlClient.Sql  替换成了 OleDb.OleDb 。使用 IDE 的查找、替换就完成了。

先写这么多。由于我没有写过OOD的程序,也没有写过三层的程序,文章里面的对OOD、三层的说法如果有不对的地方,请多多指教!

 

 

 

相关文章
|
6月前
|
机器学习/深度学习 JavaScript 算法
GAN Step By Step -- Step7 WGAN
GAN Step By Step -- Step7 WGAN
GAN Step By Step -- Step7 WGAN
|
机器学习/深度学习 编解码 计算机视觉
GAN Step By Step -- Step5 ACGAN
GAN Step By Step -- Step5 ACGAN
GAN Step By Step -- Step5 ACGAN
|
机器学习/深度学习
GAN Step By Step -- Step6 LSGAN
GAN Step By Step -- Step6 LSGAN
GAN Step By Step -- Step6 LSGAN
|
机器学习/深度学习
GAN Step By Step -- Step4 CGAN
GAN Step By Step -- Step4 CGAN
GAN Step By Step -- Step4 CGAN
|
机器学习/深度学习 数据挖掘 PyTorch
GAN Step By Step -- Step3 DCGAN
GAN Step By Step -- Step3 DCGAN
GAN Step By Step -- Step3 DCGAN
|
JSON 监控 Linux
step by step,实现自定义监控脚本
# 背景 有几个客户在使用自定义监控,通过脚本方式上报数据时,反馈我们的文档不细致,对于aliyuncli的配置不熟,对于自定义指标的部分字段的含义不理解。 因此有必要再整理一个stepbystep的文档,描述清楚每一步的具体含义。 希望能够根据这个文档,能够快速的完成一个自定义的监控脚本。 # 前置条件 * 你需要有一个阿里云官网账号 # 生成ak(accessk
2382 0
|
存储 SQL 数据库
Step By Step 一步一步写网站[1] —— 填加数据
填加数据是一个项目必不可少的部分,也是一个基础操作,使用也是最频繁的。那么您是怎么实现添加数据的呢?添加数据可以分为几种情况。1、单表添加,不需要事务。最简单最常见2、多表(主从表)添加,不需要事务。3、多表(主从表)添加,需要事务。
981 0
|
开发工具
R-Organize Data(step 2)
R is a data analysis and visualization platform.
936 0
|
JavaScript 前端开发 SEO
|
SQL 网络协议 Oracle