百度首页 | 百度空间
 
查看文章
 
DataSnap(MIDAS)三层架构中,常用事件及其触发顺序--from EastBlaze
2008年07月07日 下午 04:08

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

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

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

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

3、要深刻理解并区分开Tfield4个重要属性:ValueOldValueCurValueNewValue

4TField的事件触发顺序:

显示时触发:OnGetText

编辑时触发:OnSetText>OnValidate>OnChange

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

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

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

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

5、要搞明白TClientDataSet的状态:

State属性:dsInsertdsEditdsDeletedsBrowse

UpdateStatus()方法:usInsertedusModifiedusDeletedusUnmodified

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

注:可以对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获取数据包的过程:

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

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

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

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

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

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

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

注:

①更新过程中如果没有出错,则不会触发DataSetProviderOnUpdateError事件、ClientDataSetOnReconcileError事件。

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

③在DataSetProviderOnUpdateError事件和ClientDataSetOnReconcileError事件里可以得到字段的OldValueNewValueCurValue值。

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

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

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

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

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

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


类别:多层开发 | 添加到搜藏 | 浏览() | 评论 (3)
 
最近读者:
 
网友评论:
1
2008年07月07日 下午 05:12
沙发下先
 
2
2008年07月08日 上午 09:04
嗯~
搬個板凳,坐著看~
 
3
2008年07月08日 下午 05:17
地板了。。。
 
发表评论:
姓 名:
网址或邮箱: (选填)
内 容:
验证码:
 

     

©2008 Baidu