visual studio的文本怎么用三层架构导入数据库

visual studio的文本怎么用三层架构导入数据库,第1张

visual studio的文本用三层架构导入数据库方法如下:

三层架构中向表中添加数据的做法一般为,在表示层获得要添加的对象(即你输入的数据),然后调用业务层的添加方法。看了你写的代码,我给你的建议是:在你的GridView_RowCommand事件处理代码中,得到当前需要添加的数据,然后封装为一个对象,接着调用业务层的添加方法

先说B/S以及C/S

B/S是浏览器服务器形式,例如网站。

C/S是客户端服务器形式,例如QQ,魔兽世界等。

而三层架构并不局限于你用的是B/S还是C/S,三层架构只是一种开发模式。

UI——用户交互层,主要用于呈现页面元素或同用户交互。本层调用BLL的成员。

BLL——业务逻辑控制层,用于业务逻辑实现以及各种数据验证。本层调用DAL的成员。

DAL——数据访问层,用于同数据库打交道,存取数据都经过本层。

学ASPNET都知道它的最经典的架构是三层架构,也是目前应用得最广泛的一种架构。以前说起三层架构大家都知道MVC架构,这是html开发中用得比较多的,现在AJAX主要就是用这种架构。大家ASPNET的三层是指数据访问层,业务逻辑层和表示层,而且都知道数据访问层是用来访问数据的,业务逻辑层是用来处理一些系统的业务逻辑的,表示层就是把内容呈现出来给用户,与用户进行交互的。划分三层的好处就是每一层都是独立的,修改其中一层一般不会影响其他层的代码,这样就大大的方便了日后的维护和升级。它最大的缺点是架构和编码都比较复杂,而且对性能的提高没有任何帮助,反而还可能会降低执行效率。

有时候真的觉得“三层”编起来挺麻烦的,在ASPNET 20里,访问数据和显示出来只要拖两个控件就可以了(AccessDataSource/SQLDatasource和GridView),几分钟一个页面就出来了,而且还具备了修改中,删除,分页,排序等功能。而用三层架构就麻烦多了,先要写数据访问层的代码,接着写业务逻辑层的代码(要调用数据层的方法),最后才是表示层,也就是页面的设计,还有调用业务逻辑层的代码读取数据。(注意:表示层是绝对不会访问数据层的内容,只能通过业务层。业务层在这里是连接它们的桥梁。所以说业务层是最重要的一层)既然这样为什么还要用三层呢?前面提到的一层架构的一个很大的问题就是前台和后台代码没有很好的分开,不利于分工,第二,不利于日后的维护和升级。如果是个人主页或者是一些一个人完成的小系统用一层还是挺方面的。如果是一些比较大的系统,特别是企业级的应用,就非用三层甚至n层不可了。一般三层就很够了,再划分更多只会增加设计和编码的难度。

那到底怎么去分层呢?怎么样分层就符合三层架构原则呢?这是很多刚入门的人经常问的问题。我翻了很多本案例书,可惜很多都是一层或者是两层架构的,绝少三层的。后来研究了petshop40和下了一些国外的资料来看才开始对如何分层有点了解。我总结了一下主要有以下三种分层方式:

一:数据层不包含任何代码,只有数据库,还有相关的存储过程。

这种模式下,数据层看起来就变得很简单了。只包含你建立的数据库,和一些存储过程(注意是存储过程)。其实这些存储过程的建立也是相当复杂的(我以后会专门写一篇这方面的文章),因为它们可以完成除数据访问外的其他一些很强大的功能,如分页,实现搜索算法等。数据访问的逻辑就都放在业务层,当然业务层还包含其他一些逻辑代码。我们来看一个示例,假设数据库里有一个表BOOKS(书),建立一个存储过程GetAllBooks,用来读取书的信息,这样在业务层里编一个方法GetBookS()和一个公用数据库访问类,GetBooks()就通过数据库访问类打开连接,执行在存储过程,返回数据(返回类型可以是DataTable,DataSet,DataReader或者实体类)。业务层单独编译成一个或者几个DLL文件。接着就是表示层了,表示层通过调用GetBookS()返回数据绑定在相关的控件里。务层的方法都是在表示层调用。一般来说bookaspx和bookaspxcs都是表示层的内容。所有前台的设计,相关控件,数据缓存都是属于表示层。

二:数据层还包含所有公共数据访问代码。

这种模式和前一种差别不大,主要是把数据访问代码六到数据层。这样可以很方面实现对多数据库的支持。业务逻辑层直接调用数据层的相关访问数据的代码,完全不必了解底层是什么数据库。其他和前一种没什么分别。

三:所有数据读取都放在数据层。

这种模式下像前面所述的GetBooks()方法都是放在数据层,在业务层再定义一个GetBookS()方法以供表示层调用。这种模式下业务层不但不必了解底层是什么数据库,而且连数据库的结构都不必了解了。这可以说是最标准的三层架构了,在Microsoft的PetShop 40里就是用这种模式。

我是从“上海全鼎软件学院”毕业的————————

通常意义上的三层架构就是将整个业务应用划分为:界面层(User Interface layer)、业务逻辑层(Business Logic Layer)、数据访问层(Data access layer)。

界面层,很好理解,就是界面,apsnet里面就是webform。

业务逻辑层,就是业务逻辑的实现,比如你要做登录,就在业务逻辑层判断账号密码的正确性。

数据访问层,说白了就是访问数据库的代码。

所谓的三层架构就是将展示层、控制层和模型层层分开,通过接口的方式实现三层之间的解偶。展示层完成的试将业务信息展示给用户并将业务数据从用户收集,完成必要的合法性校验后通过接口传递给控制层;

控制层呢则是根据业务数据完成严格的数据校验,组装必要的业务数据,将不同的业务请求提交不同的业务处理模块(也就是模型层)完成业务处里,然后将模型层的返回数据转换为展示层需要的数据,进行展示;

模型层就是进行业务处里的单元,完成各种业务逻辑的处理、数据库的访问等等;其实这一层可更细分为业务处里层和数据访问层,也就是DAO层

明白了这些内容,你就应该明白你的需要了:

1、展示层:

(1)登录页面,请用户输入用户明和密码,必要时生成验证码(刚学,可以先不实现这个),简单验证后(比如数据长度等等)提交后将数据转给控制层的登录处理模块;

(2)登录成功页面:用户登录成功展示的页面(这是你的业务需要)

(3)登录失败页面:密码验证失败后的展示页面,可以转到登录页面并提示失败,或者另建立新页面;

2、控制层:

这里控制层只有一个处理模块:登录验证。将展示层提交的数据进行业务逻辑验证,比如:登录名是什么结构、不能包含什么数据;密码多长、需要什么数据、不能包含什么数据等等,都是你的业务规定;如果不成功直接返回展示层提示存在问题;通过后调用模型层的登录处理模块,进行业务处里;如果模型层处理成功,根据需要转到成功页面或者失败页面(展示层);必要时准备会话信息参数,以备后用;

3、模型层:

根据用户登录名丛书据库中读取用户信息,检验密码是不是正确(必要时后有密码加密处理);用户状态是否正确,是否允许登录等等信息校验后将结果返回就可以了

强烈建议使用微软

企业库

,而不要用什么

SqlHelper

之类的东东,在引用了MicrosoftPracticesEnterpriseLibraryDatadll和MicrosoftPracticesEnterpriseLibraryCommondll后,在

webconfig

里面配置节点

数据库连接配置

然后在代码里使用

//创建Database对象

Database

db

=

DatabaseFactory

CreateDatabase

();

//创建DbCommand对象

DbCommand

dbCommand

=

dbGetStoredProcCommand("UP_APKeyHistory_Query");

//添加输入输出参数

dbAddInParameter(dbCommand,

"@APID",

DbTypeString,

apqAPID);

dbAddInParameter(dbCommand,

"@CommunicationKey",

DbTypeString,

apqCommunicationKey);

dbAddInParameter(dbCommand,

"@MaxEffectiveTime",

DbTypeDateTime,

apqMaxEffectiveTime);

dbAddInParameter(dbCommand,

"@MinEffectiveTime",

DbTypeDateTime,

apqMinEffectiveTime);

dbAddInParameter(dbCommand,

"@MaxExpiredTime",

DbTypeString,

apqMaxExpiredTime);

dbAddInParameter(dbCommand,

"@MinExpiredTime",

DbTypeString,

apqMinExpiredTime);

dbAddInParameter(dbCommand,

"@KeyStatus",

DbTypeString,

apqKeyStatus);

List

APKeyList

=

new

List

();

//执行命令返回DataReader对象

using

(IDataReader

dr

=

dbExecuteReader(dbCommand))

{

while

(drRead())

{

APKeyListAdd(CreateAPKeyHistoryInfo(dr));

}

}

return

APKeyList;

以上就是关于visual studio的文本怎么用三层架构导入数据库全部的内容,包括:visual studio的文本怎么用三层架构导入数据库、asp.net 中的三层架构(UI层、BL层、DAL层)和B/S结构是同一种东西吗、三层架构怎么调用的等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9376186.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-27
下一篇2023-04-27

发表评论

登录后才能评论

评论列表(0条)

    保存