在线现看午夜福利片|女人16久久免费视频|鲁丝片一区鲁丝片二区鲁丝|一区二区三区欧美在线

  1. 
    
    <b id="glvx9"></b>
        1. <blockquote id="glvx9"><meter id="glvx9"></meter></blockquote>
            首頁(yè) 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實(shí)用文檔 求職招聘 論文下載
            2011中考 | 2011高考 | 2012考研 | 考研培訓(xùn) | 在職研 | 自學(xué)考試 | 成人高考 | 法律碩士 | MBA考試
            MPA考試 | 中科院
            四六級(jí) | 職稱英語(yǔ) | 商務(wù)英語(yǔ) | 公共英語(yǔ) | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT
            新概念英語(yǔ) | 成人英語(yǔ)三級(jí) | 申碩英語(yǔ) | 攻碩英語(yǔ) | 職稱日語(yǔ) | 日語(yǔ)學(xué)習(xí) | 法語(yǔ) | 德語(yǔ) | 韓語(yǔ)
            計(jì)算機(jī)等級(jí)考試 | 軟件水平考試 | 職稱計(jì)算機(jī) | 微軟認(rèn)證 | 思科認(rèn)證 | Oracle認(rèn)證 | Linux認(rèn)證
            華為認(rèn)證 | Java認(rèn)證
            公務(wù)員 | 報(bào)關(guān)員 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 期貨從業(yè)資格 | 司法考試 | 法律顧問 | 導(dǎo)游資格
            報(bào)檢員 | 教師資格 | 社會(huì)工作者 | 外銷員 | 國(guó)際商務(wù)師 | 跟單員 | 單證員 | 物流師 | 價(jià)格鑒證師
            人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業(yè)資格 | 廣告師職業(yè)水平
            駕駛員 | 網(wǎng)絡(luò)編輯
            衛(wèi)生資格 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 執(zhí)業(yè)護(hù)士
            會(huì)計(jì)從業(yè)資格考試會(huì)計(jì)證) | 經(jīng)濟(jì)師 | 會(huì)計(jì)職稱 | 注冊(cè)會(huì)計(jì)師 | 審計(jì)師 | 注冊(cè)稅務(wù)師
            注冊(cè)資產(chǎn)評(píng)估師 | 高級(jí)會(huì)計(jì)師 | ACCA | 統(tǒng)計(jì)師 | 精算師 | 理財(cái)規(guī)劃師 | 國(guó)際內(nèi)審師
            一級(jí)建造師 | 二級(jí)建造師 | 造價(jià)工程師 | 造價(jià)員 | 咨詢工程師 | 監(jiān)理工程師 | 安全工程師
            質(zhì)量工程師 | 物業(yè)管理師 | 招標(biāo)師 | 結(jié)構(gòu)工程師 | 建筑師 | 房地產(chǎn)估價(jià)師 | 土地估價(jià)師 | 巖土師
            設(shè)備監(jiān)理師 | 房地產(chǎn)經(jīng)紀(jì)人 | 投資項(xiàng)目管理師 | 土地登記代理人 | 環(huán)境影響評(píng)價(jià)師 | 環(huán)保工程師
            城市規(guī)劃師 | 公路監(jiān)理師 | 公路造價(jià)師 | 安全評(píng)價(jià)師 | 電氣工程師 | 注冊(cè)測(cè)繪師 | 注冊(cè)計(jì)量師
            繽紛校園 | 實(shí)用文檔 | 英語(yǔ)學(xué)習(xí) | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲

            2011計(jì)算機(jī)等考Delphi:Delphi客戶服務(wù)器應(yīng)用開發(fā)

            本章中我們將闡述客戶服務(wù)器體系結(jié)構(gòu)原理、如何用Delphi構(gòu)建客戶/服務(wù)器的環(huán)境和Delphi存取遠(yuǎn)程SQL服務(wù)器的編程和注意事項(xiàng)。

              2. TStoredProc部件的存儲(chǔ)過程編程

              TStoredProc Delphi 專門用來使用服務(wù)器存儲(chǔ)過程的部件。CSDEMO 中演示用TStoredProc調(diào)用存儲(chǔ)過程的窗體是TFrmExecPr

              在程序運(yùn)行中,當(dāng)按下ShipOrder按鈕,要求對(duì)ORED_STA_TUS等字段的內(nèi)容作修改以維護(hù)數(shù)據(jù)庫(kù)的一致性。字段內(nèi)容的修改任務(wù)由服務(wù)器上的存儲(chǔ)過程SHIP_ORDER完成。SHIP_ORDE的程序如下:

              PROCEDURE SHIP_ORDER

              DECLARE VARIABLE ord_stat CHAR(7);

              DECLARE VARIABLE hold_stat CHAR(1);

              DECLARE VARIABLE cust_no INTEGER;

              DECLARE VARIABLE any_po CHAR(8);

              BEGIN

              SELECT s.order_status, c.on_hold, c.cust_no

              FROM sales s, customer c

              WHERE po_number = :po_num

              AND s.cust_no = c.cust_no

              INTO :ord_stat, :hold_stat, :cust_no;

              IF (ord_stat = "shipped") THEN

              BEGIN

              EXCEPTION order_already_shipped;

              SUSPEND;

              END

              ELSE IF (hold_stat = "*") THEN

              BEGIN

              EXCEPTION customer_on_hold;

              SUSPEND;

              END

              FOR SELECT po_number

              FROM sales

              WHERE cust_no = :cust_no

              AND order_status = "shipped"

              AND paid = "n"

              AND ship_date < 'NOW' - 60

              INTO :any_po

              DO

              BEGIN

              EXCEPTION customer_check;

              UPDATE customer

              SET on_hold = "*"

              WHERE cust_no = :cust_no;

              SUSPEND;

              END

              UPDATE sales

              SET order_status = "shipped", ship_date = 'NOW'

              WHERE po_number = :po_num;

              SUSPEND;

              END

              Parameters:

              PO_NUM INPUT CHAR(8)

              該過程只帶有一個(gè)輸入?yún)?shù):PO_NUM,類型是CHAR(8)。

              在客戶端使用該過程的TStoreProc部件是ShipOrderProc,其主要屬性如下表:

              表18.19 ShipOrderProc部件主要屬性的取值

              ━━━━━━━━━━━━━━━━━━━━━━━━━━━━

              屬性名 屬 性 值

              ────────────────────────────

              DatabaseName EmployeeDemoDB

              ParamBindMode pbByName

              Params PO_NUM(輸入?yún)?shù),String類型)

              StoredProcName SHIP_ORDER

              ━━━━━━━━━━━━━━━━━━━━━━━━━━━━

              客戶端執(zhí)行SHIP_ORDER的程序如下:

              procedure TFrmExecProc.BtnShipOrderClick(Sender: TObject);

              begin

              with DmEmployee do

              begin

              ShipOrderProc.Params[0].AsString := SalesTable['PO_NUMBER'];

              ShipOrderProc.ExecProc;

              SalesTable.Refresh;

              end;

              end;

              當(dāng)用戶按ShipOrder按鈕時(shí),執(zhí)行這段程序。程序中先準(zhǔn)備輸入?yún)?shù),用ExecProc方

              法執(zhí)行存儲(chǔ)過程。調(diào)用SalesTable.Refresh方法刷新數(shù)據(jù)顯示。

              在CSDEMO應(yīng)用程序中另一個(gè)使用存儲(chǔ)過程的TStoredProc部件是DeleteEmployeeProc。它完成的任務(wù)是刪除Employee表中的記錄,并修改所有相關(guān)的表, 以維護(hù)數(shù)據(jù)的一致性。其屬性如下:

              表18.20 DeleteEmployeeProc部件主要屬性的取值

              ━━━━━━━━━━━━━━━━━━━━━━━━━━

              屬性名 屬 性 值

              ──────────────────────────

              DataBaseName EmployeeDemoDB

              ParamBindMode PbByName

              Params EMP_NUM(輸入?yún)?shù),整型)

              StoredProcName DELETE_EMPLOYEE

              ━━━━━━━━━━━━━━━━━━━━━━━━━━

              存儲(chǔ)過程DELETE_EMPLOYEE的程序如下:

              PROCEDURE DELETE_EMPLOYEE

              DECLARE VARIABLE any_sales INTEGER;

              BEGIN

              any_sales = 0;

              SELECT count(po_number)

              FROM sales

              WHERE sales_rep = :emp_num

              INTO :any_sales;

              IF (any_sales > 0) THEN

              BEGIN

              EXCEPTION reassign_sales;

              SUSPEND;

              END

              UPDATE department

              SET mngr_no = NULL

              WHERE mngr_no = :emp_num;

              UPDATE project

              SET team_leader = NULL

              WHERE team_leader = :emp_num;

              DELETE FROM employee_project

              WHERE emp_no = :emp_num;

              DELETE FROM salary_history

              WHERE emp_no = :emp_num;

              DELETE FROM employee

              WHERE emp_no = :emp_num;

              SUSPEND;

              END

              Parameters:

              EMP_NUM INPUT INTEGER

              從上述存儲(chǔ)過程的例子中,我們看到存儲(chǔ)過程在維護(hù)服務(wù)器上的數(shù)據(jù)一致性方面有很強(qiáng)的能力,它節(jié)省了系統(tǒng)開銷,提高了客戶端的性能。

              18.4.2.5 事務(wù)控制編程

              在客戶/服務(wù)器應(yīng)用程序中,事務(wù)控制是一項(xiàng)很重要的技術(shù)。它對(duì)于提高系統(tǒng)的可靠性,維護(hù)數(shù)據(jù)一致性有著重要的意義。

              Delphi中提供了事務(wù)的隱式和顯式兩種控制方法。其中顯式控制的性能較高,下面介紹Delphi事務(wù)顯式控制的編程方法。

              Delphi擔(dān)當(dāng)事務(wù)控制任務(wù)的部件是TDatabase 。TDatabase 用于事務(wù)控制的屬性是TransIsolation,方法有StartTranstion、Commit和Rollback。關(guān)于這些屬性和方法作用和使用方法請(qǐng)參閱客戶/服務(wù)器事務(wù)管理。

              在CSDEMO中TDatabase 部件為EMployeeDatabase,其TransIsolation屬性值為tiReadCommitted,意為如果存在多個(gè)同時(shí)事務(wù)訪問數(shù)據(jù)庫(kù),則其中任一事務(wù)只能讀其它事務(wù)提交的了數(shù)據(jù)。

              CSDEMO中演示事務(wù)控制的窗體是TFrmTransDemo。

              DBGrid1中顯示EmployeeTable中的內(nèi)容。當(dāng)窗口顯示時(shí),EmployeeDatabase開始一次事務(wù)控制并激活EmployeeTable:

              procedure TFrmTransDemo.FormShow(Sender: TObject);

              begin

              DmEmployee.EmployeeDatabase.StartTransaction;

              DmEmployee.EmployeeTable.Open;

              end;

              當(dāng)窗口被關(guān)閉或隱藏時(shí),EmployeeDatabase提交事務(wù):

              procedure TFrmTransDemo.FormHide(Sender: TObject);

              begin

              DmEmployee.EmployeeDatabase.Commit;

              end;

              窗口中有兩個(gè)按鈕BtnCommitEdits和BtnUndoEdits。按下BtnCommitEdits按鈕將提交當(dāng)前事務(wù),并開始新的事務(wù)控制并刷新數(shù)據(jù)。

              procedure TFrmTransDemo.BtnCommitEditsClick(Sender: TObject);

              begin

              if DmEmployee.EmployeeDatabase.InTransaction and

              (MessageDlg('Are you sure you want to commit your changes?',

              mtConfirmation, [mbYes, mbNo], 0) = mrYes) then

              begin

              DmEmployee.EmployeeDatabase.Commit;

              DmEmployee.EmployeeDatabase.StartTransaction;

              DmEmployee.EmployeeTable.Refresh;

              end else

              MessageDlg('Can''t Commit Changes: No Transaction Active', mtError, [mbOk], 0);

              end;

              按下BtnUndoEdits按鈕將返轉(zhuǎn)當(dāng)前事物,恢復(fù)原來的數(shù)據(jù),開始新的事務(wù)控制,并刷新數(shù)據(jù)的顯示。

              procedure TFrmTransDemo.BtnUndoEditsClick(Sender: TObject);

              begin

              if DmEmployee.EmployeeDatabase.InTransaction and

              (MessageDlg('Are you sure you want to undo all changes made during the ' +

              'current transaction?', mtConfirmation, [mbYes, mbNo], 0) = mrYes) then

              begin

              DmEmployee.EmployeeDatabase.Rollback;

              DmEmployee.EmployeeDatabase.StartTransaction;

              DmEmployee.EmployeeTable.Refresh;

              end else

              MessageDlg('Can''t Undo Edits: No Transaction Active', mtError, [mbOk], 0);

              end;

            上一頁(yè)  1 2 3 4 5 6 7 8 9  下一頁(yè)
              相關(guān)推薦:2010年9月計(jì)算機(jī)等級(jí)考試試題及答案解析專題
                   預(yù)告:名師解析2010年9月計(jì)算機(jī)等級(jí)考試試題答案
                   2010年9月計(jì)算機(jī)等級(jí)考試成績(jī)查詢時(shí)間及入口
                   2010年9月計(jì)算機(jī)等考成績(jī)查詢短信免費(fèi)提醒開通
            文章搜索
            版權(quán)聲明:如果計(jì)算機(jī)等級(jí)考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系800@exam8.com,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本計(jì)算機(jī)等級(jí)考試網(wǎng)內(nèi)容,請(qǐng)注明出處。