扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
PowerBuilder(PB)和Oracle分别是前端开发工具和RDBMS的主流产品。PB提供了两种与Oracle连接的接口:PowerSoft内置的数据库接口(Native Database Interface)和ODBC接口。
PowerBuilder与Oracle的连接
假定已安装Oracle客户端应用程序。可用Sqlplus或Tnsping等是否能连接到Oracle数据库,确定在SQL*NET配置文件中使用的数据库别名(Database Alias,又称服务器名,Server Name)。如有疑问,可在Oracle客户端程序目录下tnsname.ora文件中找到。另外保证搜索路径已包括SQL*NET应用程序的安装目录(如C:\ORAWIN95\BIN)。
进入PB的Database Profiles画笔,可看到所有已安装的数据库接口(PB 6.0缺省安装的是Oracle 7.3版的接口,如使用低版本的Oracle,需在安装时指定),选择“O73 Oracle 7.3”,点击“New”按钮,进入Database Profile Setup对话框。在“Connection”页输入下列信息:Profile Name:为该Database Profile起一个有意义的名称;Server:@TNS:ServerName,其中ServerName为上述数据库别名(服务器名),如@TNS:ORA73;注意:PB 9.5则没有前面那个@TNS:!!!
Login ID:Oracle数据库中实际的用户名,由于PB初次连接到数据库时要自动建立五个系统表(PowerBuilder Catalog Table:PBCATTBL,PBCATCOL,PBCATEDT,PBCATFMT,PBCATVLD,存储表的扩展属性),因此第一个连接到Oracle的用户必须具有建表、给PUBLIC角色授权等权限。例如可用SYSTEM用户进行第一次连接,此后的连接对用户则无特殊要求。
Password:该用户的口令。
设置上述内容后,即可连上Oracle。为优化数据库连接,还可设置下列选项:
Prompt for Database Information:连接时是否提示用户输入用户名和口令;
Generate Trace:启动DB跟踪工具,跟踪连接;
Thread Safe:开发需要多线程环境支持的分布式应用时,选择该项。缺省为未选,适用于非分布应用;
PBDBMS:与存储过程调用方式有关的参数。Oracle为7.2或更高版本时,清除该选项,此时带IN OUT参数的存储过程可作为数据窗口数据源。7.2版本以下,选择该项,调用PBDBMS.Put-Line建立存储过程的SQL语句,缺省是选中;
Commit on Disconnect:断开连接时,指定提交或回退未提交的事务;
Case Sensitive:连接的Oracle服务器是否区分大小写。注意该项选中时,所有主键、包含主键的表名、外键须全为大写字符;
PowerBuilder Catalog Tables Owner:指定拥有PB系统表的用户,缺省为“SYSTEM”。如果要使用多种显示格式或有效性规则,可以在不同的用户下建立几套系统表;
Table Criteria:指定满足哪些条件的表、视图和同义词可在“Select Tables”对话框中显示出来。例如DEV用户下销售子系统的表都以SALE开头,则可以用SALE%、DEV、“TABLE”、“VIEW”指定只显示DEV用户以SALE开头的表和视图;
Asynchronous:选择该项,可在一个复杂的SQL语句执行过程中,返回第一行结果前,切换到其他操作;
Number of Seconds to Wait:若上一项选中,还可进一步通过该项指定检索数据时,等待数据库响应的时间;
Retrieve Blocking Factor:决定数据窗口对象一次可从数据库取出的记录数;
Number of SQL Staments Cached:PB可将数据窗口对象产生的SQL语句和嵌入式SQL语句保存在SQL语句缓冲区,该参数指定缓冲区为PB保留的SQL语句数目。该数值可由下式计算:SQLCache=服务器OPEN—CURSORS数-5(保留的游标数)-本连接预期使用的最大游标数;
Disable Bind:指定是否将输入变量与SQL语句绑定,此参数影响PB为数据窗口对象生成INSERT语句的方式;
Static Bind:数据窗口对象检索数据前是否检测SELECT语句的合法性。
在Syntax页,还可指定日期、时间的格式等。在Preview页可查看Database Profile设置对应的PowerScript写法。
Oracle存储过程的使用
归纳起来PB 6.0中调用Oracle存储过程有以下四种方法。
方法一:以关键字RPCFUNC声明存储过程;
方法二:以DECLARE PROCEDURE语句声明存储过程;
方法三:以动态SQL语句实现;
方法四:调用函数PBDBMS.Put-Line。
一般情况下,方法一能得到较好的运行效率和更完善的功能。因此推荐使用方法一。但是某些类型的存储过程只能使用其他方法。以下重点介绍方法一和方法二。
两种方法比较起来,有以下几点主要区别:
1)方法一适用于具有IN、OUT和IN OUT参数的存储过程,而方法二仅支持IN和OUT参数,不支持IN OUT参数;
2)方法一对参数的数目无限制,方法二最多支持255个参数;
3)方法一不支持记录(Recorder)的传递,方法二可传递和接收记录。
方法一操作步骤:
1)在用户对象画笔中创建一个Class-Standard类型的,从Transaction继承的用户对象。
2)在此用户对象中,声明Local External Functions,将存储过程以RPCFUNC关键字声明为外部函数。在Declare Local External Functions对话框中按Procedures按钮选择要调用的后台存储过程,或直接输入类似subroutine TEST(long id,ref string name)RPCFUNC ALIAS FOR “DEVTEST”的语句。例如DEVTEST的参数为(id IN NUMBER,name IN OUT VARCHAR2)。
3)保存该用户对象。
4)在Application画笔中,进入应用属性对话框,在Variable Types页,将上Transaction用户对象设置为缺省的全局变量SQLCA。
5)脚本中,编码调用相应的外部函数。形式:SQLCA函数名(参数)。如可用“SQLCATEST(ln—id,ls—name);”调用例子中定义的DEVTEST存储过程。其中ln—id,ls—name为调用参数。
方法一注意事项:
1)由于PB中String类型的数据长度是动态分配的,因此对Ref String类型的参数,每次调用前需要申请足够的空间。例如上例从输入的id值检索name,后台声明的NAME数据类型为VARCHAR2(30),每次调用SQLCATEST前需要用ls—name=SPACE(30)置ls—name为足够长度的空串。
2)类似地当传递的参数为数组(后台称PL/SQL Table)时,声明参数为相应类型的动态数组,并在每次调用前设置数组上界为足够大的值。例如:DEV用户的DEPT包中声明了TYPE tbl—name IS TABLE OF VARCHAR2(30) INDEX BY BINARY—INTEGER;存储过程EMP—OF—DEPT(dept—id IN NUMBER,name OUT DEPT.tbl—name)返回部门编写为dept—id的部门的所有员工,置name数组中。假定所有部门的员工数目不超过100,则可用以下语句声明和调用DEV.EMP—OF—DEPT:
Declare External Functions对话框中:
Subroutine EMP—OF—DEPT(long dept—id,ref string name[]) RPCFUNC ALIAS FOR ″DEV.EMP—OF—DEPT″ |
PowerScript脚本中:
long ln=dept—id |
方法二使用方法:
在脚本中加入如下编码(以DEV.TEST为例):
long ln—id |
方法三使用方法:
根据输入输出参数的不同,PB中的动态SQL语句有四种格式:
1)无输入输出参数;2)只有输入参数,无输出参数;3)有确定数目输入输出参数;4)输出结果列的数目不定。其中第1)、第2)中格式的动态SQL语句也可用来调用简单的存储过程。
1)没有输入输出参数的存储过程。例如DEVDEMO1存储过程没有输入输出参数,可用下列语句调用:
sqlstring=″EXECUTE DEMO1()″ |
2)只有输入参数的存储过程。例如DEV.DEMO2(name IN VARCHAR2,birthday IN DATE)
PREPARE SQLSA FROM ″EXECUTE DEMO2(?,?);″ |
如果是7.2以下版本的Oracle,可用方法四PBDMBS.Put—Line()函数调用建立存储过程。此时需选上Database Profile中的PBDBMS复选框。
存储过程作为数据窗口的数据源
以一个简单数据窗口(显示服务器的系统时间)为例说明怎样创建存储过程作为数据源的数据窗口。
1)在某个包(如PACK—TYPE)中定义日期类型的Recorder自定义数据类型datarec;
2)创建返回系统时间的存储过程:
PROCEDURE get—sysdata(sysdt IN OUT PACK-TYPE.datarec)IS |
3)新建数据窗口,数据源选择Stored Procedure;
4)在随后的Select Stored Procedure对话框中选择get—sysdate即可。
如果作为数据源的存储过程有IN参数,则这些参数就是数据窗口的检索参数(Retrieve Argument)。
婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘﹢寮婚敐澶婄婵犲灚鍔栫紞妤呮⒑闁偛鑻晶顕€鏌涙繝鍌涜础缂侇喖顑夐獮鎺楀棘閸濆嫪澹曢梺鎸庣箓缁ㄨ偐鑺辨禒瀣厱闁哄啯鎸鹃悾杈ㄣ亜椤忓嫬鏆e┑鈥崇埣瀹曞崬螖閳ь剙岣块幋锔解拺缂佸顑欓崕鎰版煙閻熺増鍠樼€殿喛顕ч埥澶愬閳ュ厖绨婚梻鍌欑閻忔繈顢栭崨顔绢浄闁圭虎鍠楅埛鎴犵磼椤栨稒绀冮柡澶婄秺閺屾稓鈧綆鍋呯亸顓熴亜椤忓嫬鏆e┑鈥崇埣瀹曞崬螖閳ь剙岣块幋锔解拺缂佸顑欓崕鎰版煙缁嬪灝鈷旀俊鍙夊姍楠炴﹢骞囨担鍛婂€梻浣告啞缁矂宕幎钘夎Е妞ゆ劏鎳¢弮鍫熷亹闂傚牊绋愮划鍫曟⒑閸濄儱娅忛柛瀣樀閹﹢骞掑Δ浣哄幗闂佺粯锚瀵墎绮氶崸妤佸€堕煫鍥ㄦ⒒閹冲懐绱掗鍡欑М闁诡喗鐟╅幃婊兾熼柨瀣伖闂佽崵鍠愮划搴㈡櫠濡ゅ啯鏆滈柟鐑樻尵椤╂彃霉閻撳海鎽犻柣鎾存礋閺岀喖骞嗚閸ょ喐绻涢崣澶嬪唉闁哄瞼鍠栭、娆撴寠婢跺﹤袘闂佺粯鎸堕崐鏍Φ閸曨喚鐤€闁圭偓娼欏▍婵嬫⒑瑜版帗鏁辨俊鐐舵椤繑绻濆顒傦紲濠殿喗锚瀹曨剟路閳ь剟姊绘担鍛婂暈妞ゃ劌妫楃叅闁绘棃顥撻弳锕€鈹戦崒婧撶懓鏁梻渚€娼ч敍蹇涘礋椤撶偛鍙婂┑鐘垫暩婵兘寮崨濠冨弿闁圭虎鍠楅弲婵嬫煏閸繃绀岄柛瀣尭椤繈鎮℃惔锛勭潉闁诲氦顫夊ú鈺冪礊閳ь剛绱掗悩宕囨创鐎殿噮鍣e畷鎺戔堪閸涱噮娼撳┑鐘垫暩婵兘寮崨濠冨弿闁圭虎鍠栫壕鍦磽娴h偂鎴濃枍閻樺磭绠鹃柟瀛樼懃閻忣亪鏌i幘瀛樼闁诡喗顨婇弫鎰板礃閵娿儺鐎冲┑鐘殿暯閳ь剝灏欓惌娆撴煛鐏炵偓绀嬬€规洘鍎奸ˇ鍙夈亜韫囷絽骞橀柍褜鍓氶鏍窗閺囩姴鍨濇繛鍡樺姃缁诲棙鎱ㄥ┑鍡欑劸婵℃彃缍婂娲焻閻愯尪瀚板褜鍨堕幃浠嬵敍閵堝洨鐦堥悗娈垮枛椤兘骞冮姀銈呯闁绘挸娴峰顔尖攽閻橆喖鐏辨繛澶嬬洴閺佸啴濡烽妷銏$亖婵犵數濮电喊宥夊煕閹达附鐓曟繝闈涙椤忣偊鏌h箛娑楁喚闁哄本鐩幃鈺佺暦閸パ€鎷版俊銈囧Х閸嬫盯宕锔哄亼濞村吋娼欓柋鍥ㄧ節闂堟稓澧曟鐐村姍濮婄粯鎷呴崨闈涚秺瀵敻顢楅崒婊呯厯闂佽鍎崇粻宥嗙瑜版帗鍊甸柨婵嗛閺嬬喖鏌i幘璺烘灈妤犵偞鐗曡彁妞ゆ巻鍋撻柍褜鍏欓崐鏇炵幓閸ф绠涙い鎾跺Х椤旀洟姊洪崨濠勬噧妞ゃ儯鍨介、鏃堝醇閻旇渹鎮f繝鐢靛█濞佳囨偋韫囨稒鍎楁繛鍡樻尰閸嬶綁鏌熼鐔风瑨濠德ゅГ缁绘盯宕奸妷褏鏆┑顔硷攻濡炶棄鐣峰⿰鍫濈闁瑰搫绉堕崙瑙勭節閻㈤潧浠滅€殿喖鐖奸幃褔鎮╃拠鑼暫闂佺偨鍎查弸鐓幬i崼銉︾厪闊洢鍎崇壕鍧楁煕濮椻偓娴滃爼寮婚敐鍫㈢杸闁哄洨鍋樼划鑸电節閳封偓閸屾粎鐓撻梺璇″灠閻ジ鍩€椤掑﹦绉甸柛瀣缁粯銈i崘鈺冨幈濡炪倖鍔戦崐鏇㈠几閹达附鐓曞┑鐘插暙婵牓鏌熸笟鍨缂佺粯绻堝畷鐔碱敇閻愭鍋ч梻鍌欒兌閹虫捇宕查弻銉ョ疇闁归偊鍠栭崹婵嬫煟閵忋埄鏆柛瀣崌閺佹劖鎯斿┑鍫濆毈闂備椒绱徊濂稿础閸愬樊娼栫紓浣股戞刊鎾偡濞嗗繐顏╁ù鐘櫊濮婃椽宕ㄦ繝鍐弳濡炪倖鍨甸ˇ顖炴偩閻戣姤鏅搁柣妯垮皺椤︺劑姊洪懖鈹炬嫛闁告挻鑹鹃埢鎾淬偅閸愨斁鎷洪梻鍌氱墛缁嬫挾绮婚悙鐑樼厱濠电姴鍟粈瀣偓瑙勬礃閿曘垽宕洪埀顒併亜閹哄棗浜惧銈庝簻閸熷瓨淇婇崼鏇炲耿婵°倐鍋撴い顐㈡喘濮婅櫣绮欓崸妤娾偓妤冣偓瑙勬处閸撶喖骞嗛崘顕呮晢闁告洦鍏橀幏濠氭⒑缁嬫寧婀伴柣鐔濆洤绀夌€广儱顦伴崐鐢电磼濡や胶鈽夐柟铏姍閹苯鈻庨幘瀵稿幍闁诲海鏁告灙鐞氥儵姊虹粙娆惧剱闁瑰憡鎮傞敐鐐测攽鐎n偄浜楅柟鑹版彧缁辨洟鎯堥崟顖涚厽閹兼番鍊ゅḿ鎰箾閸欏鐏寸€规洩绻濆畷姗€鎳犻浣诡啎闂備礁鎲¢〃鍫ュ磹閿濆鍋勯柛蹇撶毞閹峰綊姊鸿ぐ鎺戜喊闁哥姵鑹鹃埢鏃堝锤濡や讲鎷婚梺绋挎湰閻熝呯玻閺冣偓缁绘稒鎷呴崘鍙夊闁稿顑夐弻娑㈠焺閸愵亖妲堢紓浣哄Х婵炩偓妤犵偞鐗曡彁妞ゆ巻鍋撻柣蹇d邯閺屾稑鈻庤箛鏇狀唹闂侀潧娲ょ€氫即鐛幒妤€骞㈡俊鐐村劤椤ユ岸姊婚崒娆戭槮闁汇倕娲敐鐐村緞閹邦剙鐎梺绉嗗嫷娈旈柡鍕╁劦閺屾洘寰勯崱妯荤彅濡ょ姷鍋戦崹鐑樼┍婵犲洦鍊烽柟缁樺坊閹稿啴姊洪崨濠傜伇妞ゎ偄顦遍幑銏犫攽鐎n偄浠洪梻鍌氱墛閸掆偓闁绘劗鍎ら悡鏇㈡煏婵犲繘妾柕鍥ㄧ箞閺屸剝鎷呴崜鎻掑壎闂佸搫鐫欓崶銊ユ闂侀潧鐗嗛幊宥呪柦椤忓懐绠鹃柨婵嗘噺閹兼劙鏌ㄩ弴銊ょ凹濞e洤锕畷濂稿即閻愯尙鐛╂俊鐐€栭弻銊╁触鐎n噮鏁傞柨鐔哄У閳锋帒霉閿濆懏鍤堢憸鐗堝俯閺佸嫰鏌涘☉娆愮稇缁炬儳缍婇弻娑㈡晜鐠囨彃绠洪悗瑙勬礀瀵墎鎹㈠☉銏犵婵炲棗绻掓禒鐓幬旈悩闈涗杭闁搞劎鍎ょ粚杈ㄧ節閸ヨ埖鏅┑鐘茬仛閸旀洖鈻撻鐘电<闁绘劦鍓氱欢鑼磼婢跺﹦绉虹€殿喖顭烽弫鎰板幢濡搫濡抽梻渚€娼ф蹇曞緤娴犲瑤澶娾攽閸♀晜瀵岄梺闈涚墕缁绘劙銆呴鍕厸濞达絿鐡旈崵娆愩亜閺囶亞鎮奸柟椋庡Т椤斿繘顢欓崗鐓庘偓顖炴⒒娴gǹ顥忛柛瀣浮瀹曟垿宕ㄩ幖顓熸櫅闂佹悶鍎洪崜姘跺煕閹烘嚚褰掓晲閸涱喖鏆堥梺鍝ュ枔閸嬨倝寮婚悢鐓庣濞达綀娅i弳顐︽倵鐟欏嫭绀堝褎顨婇獮鍡涘籍閸埃鍋撻敃鍌氱闁绘劕鐡ㄩ悵銊╂⒒閸屾瑧鍔嶉悗绗涘懏宕查柛宀€鍊涢崶銊ь浄閻庯綆浜濋悗顒勬⒑缁洖澧查柕鍥ㄧ矒閸┾偓妞ゆ帊绀佺粭鎺撱亜椤愶絿绠炴い銏☆殕缁绘繈宕掑鍏兼祮闂傚倸鍊烽悞锕€顪冮崸妤€鍌ㄥù鐘差儍閳ь剙鍟村畷鍗炩枎閹邦剙绨ユ繝鐢靛仦閸垶宕归崷顓犱笉濠电姵纰嶉悡娑橆熆鐠轰警鍎忛柣蹇婃櫊閺屾盯寮幆褍绁┑顔硷龚濞咃絿鍒掑▎蹇婃瀻闁诡垎鍐棊闂傚倷绀佸﹢閬嶅箠閹捐秮娲敇閻戝棗娈ㄦ繝鐢靛У绾板秹寮查弻銉︾厱婵炴垵褰夌花鍏笺亜椤愩垻孝闁宠鍨块幃娆撳矗婢舵ɑ锛侀梻浣告啞濮婄懓煤濠婂嫮鐝堕柡鍥ュ灩缁狀噣鏌ら幁鎺戝姉闁归攱妞藉娲川婵犲嫮鐣甸柣搴㈠嚬閸樺ジ鏁冮姀銈呯妞ゆ柨澧介敍婊堟煟鎼搭垳绉甸柛瀣閹﹢骞橀鐣屽幈闂佸啿鎼崯顐g鏉堫煈娈介柣鎰▕閸庢棃鏌℃担绋挎殻闁糕斁鍋撳銈嗗坊閸嬫挻銇勯弬璺ㄧ闁宠鍨垮畷鍫曞Ψ閵堝洨娉块梻鍌欑閹碱偄煤閵娾晛纾婚柣鎰惈闂傤垱绻涘顔荤凹闁绘挸鍟撮幃褰掑炊椤忓秴娈濋梺鍛婃⒒閸犳挾妲愰幒鎾寸秶闁靛⿵绠戠壕鎶芥倵鐟欏嫭绀冮悽顖涘浮閸┿垺鎯旈妸銉ь吅濠电娀娼уΛ顓㈡倵閺夋垟鏀介柨娑樺娴滃ジ鏌涙繝鍐ㄧ伌鐎规洘绻傞悾婵嬪礋椤愩倗鏋冩繝娈垮枟閵囨盯宕戦幘鎼闁绘劕寮堕ˉ婊堟煟閿濆棛绠炵€规洜鍠栭、鏇㈠Χ韫囨洖绨ラ梻鍌氬€烽懗鍓佸垝椤栫偛绀夋繛鍡楃箘缂傛氨鎲歌箛鏇炲灊濠电姴娲﹂弲婵嬫煕鐏炲墽銆掗柛妯兼暬濮婅櫣绮欑捄銊ь啈闂佺ǹ顑嗛崝娆忣嚕閸愬樊娼ㄩ柍褜鍓熷璇测槈閵忕姵顥濋柣鐘充航閸斿酣宕濋鐐粹拺閻犲洠鈧櫕鐏撻梺绋款儍閸婃洟鎮鹃悿顖樹汗闁圭儤绻冮弲婵嬫⒑缂佹〒瑙勭椤掑嫭鍎庨幖娣妽閳锋帒霉閿濆懏鍟為悹鎰剁節閺屾稒鎯斿☉妯峰亾濠靛棛鏆︾憸鐗堝笚閸嬨劑鏌涢幘鍐茬骇闁哄懏绮撳娲礃閸欏鍎撻梺鐟板暱缁绘ê鐣烽幇鏉垮瀭妞ゆ劧绲藉鍨攽椤旂瓔娈旀俊顐n殕閺呭墎绱掑Ο鍦畾闂佸湱绮敮鐐电矓濞差亝鐓涢悘鐐靛亾缁€瀣偓瑙勬礃閸庡ジ藝閸欏浜滈煫鍥风到楠炴﹢鏌嶈閸撴岸顢欓弽顓炵獥闁哄洨濮撮崹婵囩箾閸℃ê濮冪紒璇叉閹便劌鈹戦崱娆戝姼濠碘剝褰冮妶绋款潖濞差亝顥堥柍鍝勫暟閵堢兘姊虹粙鍧楊€楃痪缁㈠幖鍗遍柟鐗堟緲缁犲鎮楀☉娅亪顢撻幘鍓佺=濞达絽婀遍埥澶嬨亜閹存繃鍣归柍缁樻崌椤㈡﹢鎮欓埡鍌涙澑闂備礁鐤囧Λ鍕涘Δ浣侯洸婵犻潧鐗忕壕濂告偣閸ヮ亜鐨哄褎娲橀妵鍕即椤忓棛蓱缂備胶绮换鍌烇綖濠靛鏁囬柣鎰閻╁海绱撻崒娆掑厡闁稿鎸婚崚濠囨嚍閵夛絼绮撻梺褰掓?缁€渚€鎮挎ィ鍐╃叆婵犻潧妫Σ褰掓煕鐎Q冨⒉缂佺粯绻冪换婵嬪磼濮橆厽顔嶉梺杞扮閻楁挸顫忛搹瑙勫珰闁炽儴娅曢悘宥夋⒑閹稿孩纾搁柛銊ょ矙閻涱喗绻濋崶銊ヤ汗濠电偠灏欑划顖炲疾閵忋倖鈷戠紒瀣濠€鎵磼椤曞棛鎮兼俊鍙夊姍瀵濡烽敂瑙勫闂備礁鎲$换鍌溾偓姘槻鍗遍柟闂寸劍閻撶喐淇婇妶鍌氫壕闁诲孩纰嶅姗€鎮惧畡鎵虫斀闁搞儯鍔岄崝鍛存⒑閹稿海绠撴繛璇х悼缁厽寰勯幇顓涙嫼缂傚倷鐒﹂敋濠殿喖顦甸弻娑欐償濞戞ǚ鍋撳┑瀣畺闁炽儲鏋煎Σ鍫ユ煏韫囧ň鍋撻弬銉ヤ壕闁割偅娲橀悡鐔兼煙闁箑鐏$痪顓炲⒔閹喖顫濋懜纰樻嫼闂佸憡绺块崕杈ㄧ墡闂備焦瀵уú蹇涘垂閽樺鍤曞┑鐘宠壘閻掓椽鏌涢幇銊︽珔妞ゅ孩鎹囧娲嚒閵堝懏鐎惧┑鐘灪閿曘垽鏁愰悙鍝勭婵°倓绀侀埀顒傛暬閹嘲鈻庤箛鎿冧痪缂備讲鍋撻柛顐犲劜閻撴洟鏌eΟ铏癸紞濠⒀呮暬閺屾洟宕遍弴鐙€妲銈庡亝缁捇宕洪埀顒併亜閹烘垵顏╃紒鐘崇墵閺屽秹宕崟顒€娅ら梺璇″灣閸嬬偤濡甸崟顖氱疀闁宠桨璁查崑鎾斥攽鐎n亞顔嗘繝鐢靛У绾板秹鍩涢幒妤佺厱閻忕偞宕樻竟姗€鏌嶈閸撴瑩宕查弻銉︾畳闂備焦鎮堕崕婊堝川椤旂瓔鍟庨梻鍌欑婢瑰﹪鎮¢崼銉ョ;闁告稒娼欓惌妤呯叓閸ャ劎鈯曢柣鎾寸懇閺岀喖顢涘☉娆戝嚒閻炴碍宀稿娲箮閼恒儲鏆犲┑顔硷工椤兘宕洪埀顒併亜閹哄棗浜剧紓浣哄Т缁夌懓鐣烽弴銏$劶鐎规挶鍎卞ú顓€€佸☉銏″€烽柟缁樺笧閳ь剦鍙冨铏圭矙鐠恒劎浼囬梺绋款儑閸嬨倝骞冮敓鐘差潊闁炽儴灏欑粻姘渻閵堝棛澧紒顔肩焸閹啴骞嬮悩鐢碉紲闁哄鐗勯崝宀勫传濞差亝鐓涢悘鐐额嚙婵″ジ鏌嶇憴鍕伌鐎规洟浜堕崺锟犲磼閸岋箑顩紒杈ㄦ尰閹峰懘骞撻幒宥咁棜闂備浇顕ч崙鐣岀礊閸℃稑纾诲ù锝呮贡椤╁弶绻濇繝鍌滃闁绘挻绋撻埀顒€绠嶉崕閬嶅疮椤愶絼绻嗛柛褎顨嗛悡鍐煢濡警妯堟俊鎻掓贡缁辨帞绱掑Ο鍏煎垱閻庤娲栭妶鎼佸箖閵忋倖鎯為柛锔诲幖鐢劌鈹戦悩鎰佸晱闁哥姵鐗犻弫鍐Ω閵夈垺鐎洪梺鎸庣箓閹冲危閸儲鐓熼柕蹇婃嚉閻熼偊鍟呮繝闈涙储娴滄粓鏌¢崒娑樺姢閻庢艾閰i弻宥堫檨闁告挻宀稿畷婵嬪即閳垛斁鍋撻弮鍫濈妞ゆ柨妲堣楠炴牜鍒掗崗澶婁壕闁肩⒈鍓欓崵顒€鈹戦悩鍨毄闁稿濮锋禍绋库枎閹惧磭鐛ラ梺鍝勮癁閸涱喗顔曟繝鐢靛仜濡﹥绂嶅⿰鍫熷€块柛顭戝亖娴滄粓鏌熼崫鍕ф俊鎯у槻闇夋繝濠傚閻帡鏌″畝鈧崰鏍х暦椤愶箑绀嬫い鎺戭槹椤ワ絽鈹戦悙鑼憼缂侇喗鎸剧划濠氬冀瑜滃ḿ鏍ㄧ箾瀹割喕绨荤紒鐘卞嵆楠炴牕菐椤掆偓閻忣噣鏌嶇憴鍕姇缂佺粯绻勯崰濠偽熷畡棰佸闂佹儳娴氶崑鍛村箖濞嗘挻鐓曟俊銈呮噸閹查箖鏌″畝鈧崰鏍箖瑜斿畷濂告偄閸濆嫬娈ョ紓鍌氬€风欢锟犲磻閸曨厾鐭撶憸鐗堝笒閽冪喐绻涢幋娆忕労闁轰礁鍟撮弻銊モ攽閸℃ê绐涢梺浼欑悼閸樠団€旈崘顔嘉ч柛鈩兠棄宥呪攽閿涘嫬浠╂俊顐㈠閿濈偠绠涘☉娆愬劒闂侀潻瀵岄崢楣冩晬濠婂啠鏀介柍钘夋閻忕娀鏌熺喊鍗炰喊闁挎繄鍋涢悾婵嬪礋椤掆偓閳ь剙鐏氱换娑㈠醇濠靛牅铏庡┑鐐叉噺閿曘垽寮诲☉銏犵閻庨潧鎲¢崳顖炴⒑鐠囪尙绠伴柛鐔告綑椤繐煤椤忓嫬绐涙繝鐢靛С閼冲墎鎹㈡笟鈧娲传閵夈儛锝団偓鍏夊亾缂佸娉曢弳锕傛煏韫囧鈧洜绮婚悷鎳婂綊鏁愰崨顓炶緟闂佸綊鏀卞钘夘潖濞差亜宸濆┑鐘插暙闂夊秹鎮峰⿰鍕凡闁哥噥鍨崇划瀣吋閸℃瑯娴勯柣搴秵閸嬪棝宕㈤柆宥嗙厽閹兼惌鍨崇粔闈浢瑰⿰鍕煉妞ゃ垺妫冮、姗€濮€閿涘嫬骞嶆俊鐐€栧褰掑几婵犳碍鍤€闁秆勵殕閻撴稑霉閿濆毥褰掑汲閿濆洠鍋撶憴鍕閻㈩垱甯¢崺銉﹀緞婵犲孩鍍靛銈嗗坊閸嬫挾绱掗悩闈涗槐婵﹦绮幏鍛驳鐎n亝顔勯梻浣告啞閸ㄥ綊寮查銈嗩潟闁绘劕鎼獮銏$箾閹寸偍缂氶柨娑欑洴濮婅櫣鍖栭弴鐐测拤闁藉啳椴哥换娑㈠川椤栨锝夋煏閸パ冾伃妤犵偞甯¢獮瀣攽閸愩劋澹曢梺鐓庮潟閸婃洟藟濮橆兘鏀介柛灞剧閸熺偤鏌i幘瀛樼闁诡喗锕㈤幃娆撳箵閹哄棙瀵栭梻浣哥枃濡嫰藝鏉堚晜顫曢柟鐑樺焾濞撳鏌ㄩ弴妤€浜惧┑鐐额嚋缁犳捇骞冮垾鏂ユ瀻闁规儳顕崢浠嬫⒑缂佹ɑ鐓ラ柟璇х磿濞嗐垽宕f径鍫滅盎闂婎偄娴勭徊钘夘嚕椤曗偓閺屸€崇暆閳ь剟宕伴弽顓炵畺闁斥晛鍟崕鐔兼煏韫囥儳鎮兼い銏犳嚇濮婄粯鎷呴悜妯烘畬閻庢鍠栭悥濂哥嵁閹版澘绀冮柤纰卞墯濞堥箖姊虹紒妯荤叆闁告艾顑夎棢闁割偆鍠撶粻楣冩煙鐎电ǹ浠ч柟鍐插閺岋絽鈹戦幘鍓佺槇濠殿喖锕ら…宄扮暦閹烘埈娼╂い鎴f娴滈箖鏌熼梻瀵割槮缁惧墽鎳撻—鍐偓锝庝簼閹癸綁鏌i鐐搭棞闁靛棙甯掗~婵嬫晲閸涱剙顥氬┑掳鍊楁慨鐑藉磻閻愮儤鍋嬮柣妯荤湽閳ь兛绶氬鎾閻樻爠鍥ㄧ厱閻忕偛澧介悡顖氼熆鐟欏嫭绀€闁宠鍨块、娆撴儗椤愵偂绨婚柣锝囧厴椤㈡宕熼銏犱憾闂佽娴烽弫鍝ユ兜閸洖纾婚柟鎹愬煐閸犲棝鏌涢弴銊ュ妞わ负鍎崇槐鎾诲磼濮樻瘷銏ゆ煥閺囥劋绨绘い鏇稻缁绘繂顫濋鈧懓鍨攽鎺抽崐鏇㈡晝閵堝绠栭柟杈鹃檮閳锋垿鏌涘☉姗堟缂佸爼浜堕弻娑㈠Ω瑜庡▍鏇熶繆閸欏濮嶉柡灞芥椤撳ジ宕卞▎蹇撶闂備胶顢婃竟鍫ュ箵椤忓棙顫曢柡鍥ュ灪閸嬧晜銇勯幘鍗炵仾闁绘挻娲熼獮鏍庨鈧俊娲煙閺屻儳鐣洪柟绋匡工閳规垿宕伴姀鐘电Ш鐎规洘顨婂畷妤呮嚃閳哄啠鏋忕紓鍌欒兌閸嬫挸鐣峰Ο琛℃灃闁哄洢鍨归悞鍨亜閹哄棗浜剧紓浣哄Т缁夌懓鐣烽弴銏$劶鐎规挶鍎卞ú锔锯偓浣冨亹閳ь剚绋掗敋濞存粍顨婂娲传閸曨剙鍋嶉梺鎼炲妽濡炰粙骞冮垾鏂ユ闁靛骏绱曢崢閬嶆⒑闂堟侗妾х紒韫矙瀹曟繂顫濋鑺ユ杸闂佹寧绋戠€氼剛鏁懜鐐逛簻妞ゆ挴鈧啿濮峰銇卞倻绐旈柡灞剧洴婵℃悂濡堕崨顓犮偖婵犵數濮崑鎾炽€掑锝呬壕濠殿喖锕ㄥ▍锝囨閹烘嚦鐔煎箻閾忣偉纭€缂備緡鍠楀Λ鍐€佸璺虹劦妞ゆ帒瀚ㄩ埀顑跨窔瀵噣宕煎┑瀣暪闂備胶绮Λ浣糕枍閿濆姹查柕蹇嬪€栭埛鎺楁煕鐏炴崘澹橀柍褜鍓涢崗姗€骞冮悙鐑樻櫆闂佹鍨版禍鍓х磼濡や胶鈽夐柟鍐茬箰閻g兘寮婚妷锔惧幈闁诲繒鍋熼搹搴ㄥ吹閵堝棛绠鹃柟瀵稿剱閻掓悂鏌¢崘銊у鐎瑰憡绻冮妵鍕箻鐠虹洅銏☆殽閻愭潙娴慨濠勭帛閹峰懘宕ㄦ繝鍐ㄥ壍婵犵數鍋涢惇浼村垂閽樺鏆﹂柣鐔稿櫞濞差亶鏁傞柛娑卞幒缁ㄧ敻姊绘担鍛婂暈闁告棑闄勭粋宥呪攽鐎n亞鐛ラ梺褰掑亰閸樺墽寮ч埀顒佺節閻㈤潧孝闁稿﹦绮弲鍫曞即閻樼數锛滈梺閫炲苯澧寸€规洖銈搁幃銏㈢矙閸喕绱熷┑鐘殿暯濡插懘宕规潏鈹惧亾缁楁稑鎳忛崗婊兾旈敐鍛殲闁绘挶鍨介弻娑㈠箛閸忓摜鐩庨梺鍝勵儐閻╊垶寮婚敍鍕勃闁绘劦鍓涢ˇ銊х磽娴h櫣甯涚紒瀣墵钘濋柡灞诲劜閸婂灚鎱ㄥΟ鍝勮埞闁告ê顕埀顒冾潐濞叉﹢宕归幐搴濈箚闁归棿绀侀悡娑㈡煕鐏炵虎娈曢悗姘冲亹缁辨捇宕掑顑藉亾閻戣姤鍊块柨鏇炲€归弲顏勨攽閻樻剚鍟忛柛鐘崇墪鐓ら柨鏇炲€告闂佸憡娲﹂崹浼村础閹惰姤鐓忓┑鐐茬仢閸旀氨绱掗銏⑿ф慨濠呮閸栨牠寮撮悢鍛婄翻闂備焦鎮堕崝蹇撐涢崟顖f晪闁挎繂顦粻缁樸亜閺冨倵鎷℃繛鐓庯躬濮婃椽鎮欓挊澶婂闂佸搫顑呴妶绋跨暦閹达箑绠荤紓浣姑禒娲⒑閸涘﹦鈽夐柨鏇畵瀹曪綁宕卞缁樻杸闂佺粯岣跨划顖氣槈瑜庢穱濠囶敃閿濆孩鐤侀梺绯曟杹閸嬫挸顪冮妶鍡楃瑨闁稿﹤缍婂畷鐢稿焵椤掑嫭鈷戦悗鍦閸ゆ瑧绱掓径灞惧殌闁伙絿鍏樺畷濂稿即閻愬秮鏅犻弻銊モ攽閸℃浼€闂佺儵鏅涢柊锝咁潖缂佹ḿ绡€閹肩补鈧尙鐩庢繝鐢靛仩椤曟粍淇婇崶鈺佸灊婵炲棙鎸哥粻娑㈡煛婢跺孩纭堕柣銈呮噺娣囧﹪濡惰箛鏇炲煂闂佸摜鍣ラ崹鍫曞箖閳ユ枼妲堥柕蹇娾偓鏂ュ亾閸洘鐓熼柟鎵濞懷兠瑰⿰鍐ㄢ挃缂佽鲸甯¢崺鈧い鎺戝€甸崑鎾绘晲鎼粹€冲箣闂佺ǹ顑嗛幐楣冨箟閹绢喖绀嬫い鎺戝亞濡茬懓鈹戦悙鑼憼缂侇喖鐭傞幃銉︾附缁嬭銉ッ归敐鍛棌婵炵鍔戦弻宥堫檨闁告挾鍠栭悰顕€宕橀纰辨綂闂佹寧绋戠€氭澘顬婇鐣岀瘈闁靛骏绲剧涵鐐亜閿曚線鍝虹€垫澘瀚伴弫鎾绘晸閿燂拷