QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5000|回复: 0
打印 上一主题 下一主题

用BCB开发多层数据库应用程序

[复制链接]
字体大小: 正常 放大
韩冰        

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 12:36 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>邓未玲 2000-11-16 16:27:11 </P>* d% A5 u/ C9 R* ^
<>  继Client/Server结构在MRP、MIS等数据库应用系统红火之后,多层结构(Multi_T </P>$ s  Z+ `4 \: C- e
<>ier)开始登场,许多厂商提供了各种中间件。本文描述了用Borland C++ Builder(以 </P>" n" B5 U! G3 Q8 [0 H& W+ M
<>下简称BCB)所提供的Multi_Tier构件来开发多层数据库应用程序的方法。 </P>
( c* O3 B$ \7 Z% }<>  一、 Multi_Tier结构的实现 </P>& y- q' Z' ^2 U/ M- q
<>  C++ Builder提出的Multi_Tier是把以前的Client/Server前端应用程序里的BDE、S </P>
  c( f, ], u" Z5 ?: u( |<>QL Link和DataModule拿到另一台NT服务器上,也叫应用程序服务器,前端机只留下应用 </P>. J9 c! i. |6 b; f/ h& T
<>程序及DBClient.DLL,而移到应用程序服务器上的DataModule则变成一个COM程序,此COM </P>$ e, }$ F- t7 n5 e8 j
<>程序是通过BDE 、SQL Link传输SQL到后端数据库,并从后端数据库存取数据,然后由Td </P>
* M$ j- [4 ?% Z& I2 R1 [, z<>atasetprovider组件把读取的Dataset压缩并切割成一段一段的数据包(data packet) </P>+ F, D4 ~& O, B/ @8 S
<>通过DCOM的机制传给前端机,前端机上的DBClient.DLL会把接收到的数据包再还原成Da </P>6 }7 L* n) x- h2 @; k/ i' g
<>taSet传给程序中的TclientDataSet组件,Data Control组件就可以TclientDataSet为数 </P>
+ G2 Y) {; `6 X8 p. l9 |% X* @: r<>据源对之进行操作,而COM程序会把修改后的DataSet正确地写回后端数据库。 </P>
8 }5 ^& T7 l0 N% w* S+ l6 A# J<>  与Client/Server结构相比,Multi_Tier结构具有很多优点,主要表现在: </P>: E1 I8 f" B( |. M0 ]5 n% c" C
<>  1. 大幅度地减少数据库服务器的负担。因为多了一层应用程序服务器,接管了众多 </P>
+ W5 D' d$ m6 `1 T" R3 R3 y<>客户机的Connection处理,数据库服务器只需处理应用服务器的Connection,这样就不 </P>3 o; z8 w, i! |2 y3 ~6 ^/ A% m. z7 s
<>会因为用户(Client)数的增加而影响系统的运行性能。 </P>" Q1 f7 ]' u9 ^; [
<>  2. 前端机应用程序安装方便。Multi_Tier结构中,把以前的Client/Server前端应 </P>/ P) J: T" D; I
<>用程序内的BDE、SQL Link和DataModule拿到数量很少的应用服务器上,前端机只负责U </P>2 Y; p, i3 G# |4 D  @
<>se Interface的处理,只需要一个单纯的EXE文件(包括DBClient.DLL),可以在应用服 </P>1 h! y/ H$ ]  |% a' J5 ^
<>务器上开发前端应用程序,通过网络复制到各个前端机上。 </P>2 ]2 Z8 z& L/ ]6 }6 m! T
<>  二、 环境配置 </P>' u4 ?4 a0 ~* k$ D) b
<>  1.后端数据库服务器配置 </P>
2 u9 |  V! z. ~: b, O4 c8 X<>  包括数据库系统及数据库提供的中间件。本文具体环境为: </P>
* V( L5 p. \9 F% a, Q5 F<>  VMS操作系统上安装Oracle7.3。 </P>
+ T1 c5 ]6 }5 v/ g; d& J7 G<>  2.应用程序服务器配置 </P>/ m" T0 x5 x( }
<>  (1)在PC Server上安装Windows NT ,使它成为一台Microsoft NT Server; </P>
; a6 J4 Y: l- D" N) p<>  (2)保证网络的畅通,即网络层的通讯协议的畅通; </P>
3 @! V8 C- \7 l& h' y' x* w<>  (3)安装数据库系统提供的中间件,本文是Oracle提供的Oracle for NT 的SQL?N </P>1 w& T, t0 [+ K9 s
<>ET产品,执行SQL?NET Easy Configuration工具,设定Oracle的TNS连接参数,加入一个数 </P>3 o" m  |. \' Z7 L
<P>据库别名,连上后端的Oracle数据库服务器;
4 l' o9 z& [9 x" K  (4)安装BDE Administrator,设定BDE的参数内容,具体步骤如下: </P>$ h3 t. J5 U# ~% h+ T
<P>  Databases中先新建一个别名,本文是Oracle2,其中的参数改为: </P>$ k+ X+ W% }/ X; C7 a
<P>server name   数据库服务器的别名 </P>
: u5 @* B! t$ E% o5 H<P>net protocol   tns </P>0 _$ b/ c9 ~' F7 @4 g' H. ]
<P>user name    oracle的用户名/口令 </P>( X: K$ I3 K1 l4 e: x
<P>  (5)安装C++Builder 5软件,用于开发应用服务器和客户端的程序。 </P>9 H' ^% T$ R4 s; Q, z7 w
<P>  3.前端客户机配置 </P>
8 W+ i% E* Z5 [" o<P>  (1)安装操作系统Windows 95/98,本文是Windows 98,保证各前端机与应用服务器 </P>& |' ?, b1 {8 U& ?3 L) e/ x
<P>在TCP/IP层上连通; </P>
, V  W, |2 S3 |" o1 s) U( W<P>  (2)从NT服务器的WinntSystem32目录下复制DBClient.DLL到本机的WindowsSyste </P>0 Z" [$ `/ y7 d1 r+ Z
<P>m; </P>  ^$ ^: l4 i( H0 R0 h: ]( a
<P>  (3)如操作系统为Windows 95,必须安装DCOM程序,因为Windows 98 与Windows NT </P>
3 z1 d, X. `0 P0 ^<P> Workstation已经内含DCOM程序,不需另外安装; </P>
' Y8 y+ ~4 k' d& B: i% Z<P>  (4)在应用服务器上开发应用程序,通过网络复制。 </P>
2 H# A: b, l4 i8 F5 U. V+ ^<P>  三、实现步骤 </P>
+ n5 I. S, v5 }<P>  下面是一个对材料库存表进行维护的Multi_Tier结构数据库管理程序,用户可以在 </P>
% U+ |2 y! }6 K. \# i; T8 F+ U<P>前端的Windows 98机上通过中间的NT应用服务器对Alpha机上的Oracle数据库上的库存表 </P>7 a) b7 Z7 v1 `' V& }3 v
<P>进行维护。 </P>+ E" Y% |4 S( C( U0 ^$ w3 Y' \$ `. h
<P>  1.应用服务器上程序的开发 </P>
  X  F3 x" r' Y- X' J; i; V4 B<P>  (1)打开一个新工程,然后点主功能选单NEW中的RemoteDataModule,并填入Cocla </P>5 ^/ V; S& ^8 C4 a) I/ W3 B
<P>ss Name项,这里是KCBB。 </P>- Q! |) }; u; ]# t. Q! E' l2 S
<P>  (2)在RemoteDataModule上放置DATABASE,TABLE,DataSetProvider三个组件,并分 </P>
0 v4 H* ?; U4 y' a. X<P>别设置属性如下: </P>
) }, Y$ X" X4 t<P>database1 aliasname   oracle2 </P>$ |( ^3 m  N, u$ ~' Q7 D
<P>     databasename  test </P>
9 j  d  J" N  f7 m<P>     connected    true </P>
- s& o2 V: s8 D# r5 a" q<P>table1 databasename   test </P>
* f) K3 g' f: }# S% X<P>    tablename    kcb </P>* Y7 O/ k! j( u# Z
<P>    active     true </P>
1 w! [: f) K  G6 ]5 r<P>datasetprovider  dataset  table10 </P>3 S' w6 ?! t; t! A
<P>         expo0rted t rue </P>
( O$ u# P! C2 {1 F<P>  前六行目的是连上后端数据库Oracle2的表KCB,后两行目的是DataSetProvider组件 </P>
$ V; a3 l* Y* m/ i/ D9 ~4 ?<P>将表KCB作为DATASET传给前端程序。 </P>
# `0 _7 ]( W, G; ]<P>  (3)在Forms1加一个Lable组件,上面写上“服务器应用程序已被启动”,这样运行 </P>
3 h0 l# W( P' V) \3 U; e8 @<P>时屏幕上就会出现这句话,说明程序已被调用。 </P>
- b0 o. v4 G2 V<P>  (4)为了前端程序能连上此COM程序,必须把它注册到服务器的注册表内,可通过运 </P>* o8 H1 g- q( Q+ f& m
<P>行Regedit.EXE,根据Coclass Name寻找注册名来确认注册是否成功。 </P>
; e6 a( n0 k, O. L<P>  2.前端程序的开发 </P>
- ?/ q0 [4 e% J: T+ \<P>  (1)打开一个新工程,拖拉一个DCOMConnection组件、一个ClientDataSet组件、Dat </P>( S5 N: S  q4 @+ _9 k
<P>aSource组件、Dbgrid组件到FORM1上。 </P>
& F# m, \, \( ^! F3 g& `/ k/ u' U3 P<P>  DCOMConnection1设置如下属性: </P>, I* F! u0 i7 T; t& ?$ Z; ?' L
<P>computername 应用服务器的机器名 </P>' h! O6 O/ {: y% S
<P>servername   project1.kcbb </P>
/ `/ v3 Q7 l* p! [<P>  ClientDataSet1设置如下属性: </P>
3 o( I4 B7 I" c- s& W( e: Z<P>remoteserver dcomconnection1 </P>
% E' F9 r& @+ \1 ~5 j<P>provider   table1 </P>: \( M# S, O' y% ?; [% i0 {0 |
<P>active     true </P>
, U: S( ]' j: D) M! X6 ^<P>  DataSource的DATASET设置为ClientDataSet1; </P>0 |* K* [; H# ^
<P>  Dbgrid的DataSource设置为DataSource1。 </P>$ c& g. w- a7 E5 u- V( K
<P>  (2)拖7个Button来当作功能按钮 ,分别设为新增、修改、删除、取消、写入、重新 </P>" G# e. a8 d: j/ C9 B
<P>读取、返回 。由于BCB提供了ActionList组件,其中包括了StandardAction,可以利用这 </P>1 t. w5 {- \* y
<P>些标准的Action来编写Dataset的编辑功能, 只要把Button的属性Action依照每Button所 </P>5 ^: P2 w' ~9 l/ X3 J
8 t2 J( g& X. v5 d- x, e  D6 a
<P>赋予的功能指向对应的ActionList项即可。 </P>' D& d0 y  I8 Q! k
<P>  最后,将调试好的前端程序复制到所有的前端机中,运行调试,一个Multi_Tier结 </P>
7 j, x1 V4 J+ s. [7 G8 B, i/ ]<P>构的数据库应用程序就可投入使用了。 </P>
# Z. h) v1 U9 {3 ]" j2 c<P>  本文仅仅描述了开发Multi_Tier结构的数据库应用程序的一种基本方法,还需要我 </P>
& g! s4 n6 b7 X! q<P>们在实际应用中进一步完善,如怎样提高数据在其上的传输效率及数据传输中的出错处 </P>$ t8 C! R+ ?8 B% A5 J; Z
<P>理等都需要进一步地编程实现 </P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-6-12 12:43 , Processed in 0.432035 second(s), 52 queries .

回顶部