DataSnap(MIDAS)三层架构中,常用事件及其触发顺序

类别:编程语言 点击:0 评论:0 推荐:

1、              知道事件触发顺序的重要性和必要性

实现一项功能通常要做两件事:a)首先要知道在哪里控制;b)其次要知道如何控制。

然而,很多情况下都是我们已经知道怎么去控制,但不知道控制点选在哪里。这主要是因为我们对组件事件的触发顺序搞不清楚。

2、              要深刻理解TclientDataSet的两个重要属性:Data、Delta

3、              要深刻理解并区分开Tfield的4个重要属性:Value、OldValue、CurValue、NewValue

4、              TField的事件触发顺序:

显示时触发:OnGetText

编辑时触发:OnSetText->OnValidate->OnChange

(1)       OnGetText事件是访问DisplayText或Text时触发。如果数据库中存储的值和要显示给用户看的值不一样,如数据库中存储的是bool型的值,要显示给用户“真”或“假”,可以在这个事件里进行处理。

(2)       OnSetText事件是设置字段的值时触发。

(3)       OnValidate事件是字段的值写入记录缓冲区前触发。可以在这个事件里对字段的值进行验证。

(4)       OnChange事件是字段的值写入记录缓冲区后触发。这个事件经常用到。

5、              要搞明白TClientDataSet的状态:

State属性:dsInsert、dsEdit、dsDelete、dsBrowse

UpdateStatus()方法:usInserted、usModified、usDeleted、usUnmodified

 

假如:新增数据,并向数据库更新的情况

 

 

注:可以对ClientDataSet定义一个属性CustomStatus来显示数据集当前实际所处的状态(新增、修改、删除、浏览)

a、        新增状态csInsert:(ClientDataSet->State==dsInsert)|| (ClientDataSet->UpdateStatus()==usInserted)

b、        修改状态csModify :(((ClientDataSet->State==dsEdit)&&( ClientDataSet->UpdateStatus()==usUnmodified)) || (ClientDataSet->UpdatesStatus()==Modified))

c、        浏览状态 csBrowse :(ClientDataSet->State == dsBrowse) && (ClientDataSet->UpdateStatus() == Unmodified)

d、        删除状态 csDelete :ClientDataSet->UpdateStatus() == usDeleted

 

6、              三层结构中ClientDataSet获取数据包的过程:

(1)ClientDataSet执行Open()时将触发以下一系列事件   

 

注:事件后标注“例”的说明在BCB或delphi的帮助中有例程。


 

(2)调用ClientDataSet的DataRequest()方法请求数据,将触发下列一系列事件

注:调用这个方法将调用IAppServer的AS_DataRequest(),将触发TDataSetProvider的OnDataRequest事件,这样就可以获取特定的数据。

 

注:事件后标注“例”的说明在BCB或delphi的帮助中有例程。

 

7、              三层结构中向数据库更新数据的过程:

(1)假如:向单表中添加多条记录,先调用ClientDataSet的Insert(),然后Post()到本地缓存,最后调用ApplyUpdates();在应用程序服务器再调用DataSetProvider->ApplyUpdates()向数据库服务器申请更新。

 

注:

①更新过程中如果没有出错,则不会触发DataSetProvider的OnUpdateError事件、ClientDataSet的OnReconcileError事件。

②更新过程中如果出错,则不会触发DataSetProvider的AfterUpdateRecord事件。

③在DataSetProvider的OnUpdateError事件和ClientDataSet的OnReconcileError事件里可以得到字段的OldValue、NewValue、CurValue值。

注:事件后标注“例”的说明在BCB或delphi的帮助中有例程。 

(2)对于主细表情况,向数据库更新数据必须用嵌套表的形式,情况更为复杂一些,但可以从上述推理。

 

8、              开发三层结构程序的几点意见:

(1)       一定要养成客户端程序与中间层程序连调的编程习惯。

 

(2)       对于一些可以放在客户端也可以放在中间层的业务规则,则如果需要与用户交互,就放在客户端,否则最好放在中间层。

 

(3)       在编写客户端程序时,也要坚持一个原则:能在后台处理的就不要在前台处理。注意:数据库应用程序在逻辑上都可以分为三层:界面层、数据链路层、数据源层。界面层放置数据感应控件,数据链路层放置数据访问组件。客户端程序数据源层是应用程序服务器,所以我把界面层称为“前台”,把数据链路层称为“后台”。

 

  

 

本文地址:http://com.8s8s.com/it/it25372.htm