青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

事務--<>

Posted on 2010-05-11 23:32 Prayer 閱讀(579) 評論(0)  編輯 收藏 引用 所屬分類: 數據庫,SQL 、DB2

務(transaction)是一個或多個接連在一起作為一個邏輯單位運行的SQL語句。DBMS認為事務是不可分割的,要么全部執行,要么全不執行。

用銀行的例子來說明事務的重要性是很經典的。假定某個客戶從他的儲蓄賬戶向支票賬戶轉賬500美元。這個操作包括連續執行的兩個獨立步驟。

(1) 儲蓄賬戶減500美元。

(2) 支票賬戶增500美元。

圖14-1顯示了這個事務的兩條SQL語句。設想,如果DBMS在執行了第一條語句,但沒有執行第二條時突然發生故障——斷電、系統崩潰、硬件出問題,賬戶在神不知鬼不覺的情況下出現了不平衡。瀆職控告和牢獄之災就會接踵而至。

圖14-1 當銀行客戶從儲蓄賬戶向支票賬戶轉賬時,必須有兩條SQL語句

為了避免違法記錄,應該使用事務來保證兩條SQL語句都被執行,以維持賬戶平衡。如果事務中的一條語句無法執行時,DBMS將撤銷(回滾)事務中其他語句。如果一切順利,變化將被持久化(提交)。

執行事務

要了解事務如何工作,就要了解一些術語。

提交。提交(committing)事務是使自事務開始后修改的所有數據持久化在數據庫中。在事務提交后,即使發生崩潰或其他故障,事務帶來的所有變化仍然對其他用戶可見并能夠保證持久化。

回滾。回滾(rolling back)事務是撤銷事務中SQL語句帶來的所有變化。事務回滾后,此前影響到的數據回到原狀,就好像SQL語句從未執行一樣。

事務日志。事務日志文件(transaction logfile)或日志(log)是有關事務對數據庫進行修改的一系列記錄。事務日志記錄了每個事務開始、數據的變化以及撤銷或重新執行事務(如果將來需要)的足夠信息。日志隨著數據庫事務的執行不斷增長。

盡管保證每個事務本身的完整性是DBMS的職責,但依據組織或公司規章來開始和結束事務以保證數據邏輯的一致性則是數據庫開發人員的責任。事務應該僅包含能做出一致修改的必要的SQL語句——不多不少。所有引用表中的數據在事務開始前和事務結束后必須保持一致。

在設計和執行事務時,要重點考慮以下方面。

l 事務相關的SQL語句會修改數據,所以執行事務要得到數據庫管理員的授權。

l 事務過程應用于那些改變數據和數據庫對象的語句(INSERT、UPDATE、DELETE、CREATE、ALTER、DROP——因不同DBMS而異)。對于工作中用到的數據庫,每一條這樣的語句都應該作為事務的一部分執行。

l 提交了的事務被稱作持久化,意味著永久性改變,即便系統發生故障仍能保持。

l DBMS的數據恢復機制依賴于事務。當DBMS在故障之后被在線復原,DBMS檢查事務日志確認是否所有事務都提交給了數據庫。如發現沒有提交(部分執行)的事務,依據日志將它們回滾。必須重新提交回滾的事務(盡管一些DBMS能夠自動完成沒有結束的事務)。

l DBMS的備份/恢復設備依賴于事務。備份設備獲得例行的數據庫快照并將它們和隨后的事務日志存儲在備份盤上。假定使用的硬盤發生故障使得數據和事務日志不可讀??梢越柚诨謴驮O備,它將采用最近的數據庫備份并執行,或前滾所有從快照到故障前最后執行并在日志中提交的事務。這個恢復操作使數據庫恢復到故障發生前的正確狀態(注意,要再次提交沒有提交的事務)。

l 顯然,應該將數據庫和它的事務日志存儲于不同的物理硬盤。

并發控制

對人來說,計算機好像在同一時間運行著兩個或更多進程。實際上,計算機操作并非同時發生,而是連續的。同時發生的印象是因為微處理器在人們難以察覺的很短的時間段內工作。在DBMS里,并發控制是在兩個或更多用戶同時訪問或修改相同的數據時為防止數據失去完整性的一組策略 。

DBMS使用鎖定策略來保證事務完整性和數據庫的一致性。在讀寫操作時,鎖定限制數據的訪問;于是,它阻止用戶讀那些正在被其他用戶修改的數據,并防止多用戶同時對同一數據修改。如果沒有鎖定,數據可能發生邏輯錯誤,針對這些數據執行的語句將返回不可預料的結果。偶爾會出現兩個用戶都鎖定了對方事務所需的數據并嘗試去得到對方的解鎖,這時發生死鎖問題。大多數DBMS能夠偵測和解決死鎖問題,通過回滾一個用戶的事務讓另一個事務可以運行(否則,兩個用戶都要永遠等對方解鎖)。鎖定機制非常復雜,請查閱DBMS文檔了解鎖定。

并發透明性是從事務的角度看數據庫上運行唯一事務的現象。DBMS分離事務變化與任何其他并發事務的變化。當然,事務永遠見不到數據的中間狀態;或在其他并發事務之前訪問,或在其他并發事務結束以后訪問。分離的事務允許重載開始數據并再次執行(前滾)一系列事務來達到它們在最初的事務被執行之后的狀態。

因為事務按照要么全部,要么全不方式被執行,事務的邊界(開始點和結束點)必須清晰。邊界使DBMS作為一個原子單元來執行這些語句。事務隱式開始于第一個可執行的SQL語句或顯式使用 START TRANSACTION語句。事務顯式結束于COMMIT或ROLLBACK語句(無法隱式結束),且無法在提交之后回滾事務。

q

 
Oracle和DB2的事務總是隱式開始,這些DBMS沒有用來開始事務的語句。在Microsoft Access、Microsoft SQL Server、MySQL和PostgreSQL中,可以使用BEGIN語句顯式開始事務。SQL:1999引入START TRANSACTION語句——由于這發生在DBMS使用BEGIN開始事務很久以后,因此不同DBMS擴展BEGIN的語法也各不相同。MySQL和PostgreSQL支持START TRANSACTION(作為BEGIN同義詞)。

þ  顯式開始一個事務中

在Microsoft Access或Microsoft SQL Server中,輸入:

BEGIN TRANSACTION;

在MySQL or PostgreSQL,輸入:

START TRANSACTION;

þ  提交事務中

輸入:

COMMIT;

þ  回滾事務中

輸入:

ROLLBACK;

代碼14-1中的SELECT語句顯示UPDATE操作被DBMS執行后又被ROLLBACK語句取消。結果見圖14-2。

                                    圖14-2 運行代碼14-1的結果。SELECT語
句的結果顯示DBMS取消了操作

代碼14-1 在一個事務內,更新操作(像插入和刪除操作那樣)永遠不是在最后出現。結果見圖14-2

SELECT SUM(pages), AVG(price) FROM titles;

BEGIN TRANSACTION;

  UPDATE titles SET pages = 0;

  UPDATE titles SET price = price * 2;

  SELECT SUM(pages), AVG(price) FROM titles;

ROLLBACK;

SELECT SUM(pages), AVG(price) FROM titles;

代碼14-2顯示更實用的事務例子。要從表publi- shers刪除出版社P04而不產生引用完整性錯誤。因為表titles的有些外鍵值指向表publishers的出版社P04,所以要先刪除表titles、titles_authors、和royalties中相關的行。應該使用事務保證所有DELETE語句都被執行。如果只有一些語句執行成功,數據將無法保持一致(要了解更多有關引用完整性檢查的信息,參見11.7節)。

代碼14-2 使用事務從表publishers中刪除出版社P04,及刪除其他表中與P04相關的行

BEGIN TRANSACTION;

  DELETE FROM title_authors

    WHERE title_id IN

      (SELECT title_id

         FROM titles

         WHERE pub_id = 'P04');

  DELETE FROM royalties

    WHERE title_id IN

      (SELECT title_id

         FROM titles

         WHERE pub_id = 'P04');

  DELETE FROM titles

    WHERE pub_id = 'P04';

  DELETE FROM publishers

    WHERE pub_id = 'P04';

COMMIT;

ACID

ACID是首字母縮寫,它概括了事務的特點:

原子性(Atomicity)。要么事務中所有的數據修改都執行,要么都撤銷。

一致性(Consistency)。完全的事務應讓數據保持一致來保證數據完整。一致狀態要保證滿足所有數據約束。(注意,并不要求在任何事務的中間點保持一致性)。

隔離性(Isolation)。事務的影響獨立(或隱藏)于其他事務,參見14.1節“并發控制”提要欄。

持久性(Durakility)。在事務完成后,它的影響是永久和持續的——即便是系統崩潰。

事務理論是獨立于關系模型的重大問題。由Jim Gray和Andreas Reuter所著的Transaction Processing: Concepts and Techniques(Morgan Kaufmann)是一本很好的參考書。

ü提示

l 不要忘記使用COMMIT或ROLLBACK顯式結束事務。沒有結束點將導致回滾的最后未提交事務巨大,可能帶來意外的數據變化或程序異常中止。因為事務在生存期鎖定行、整個表、索引和其他資源,所以要讓事務盡可能小。COMMIT或ROLLBACK為其他事務釋放資源。

l 可以嵌套事務。最大嵌套數因DBMS而異。

使用一條SET語句的UPDATE更新多個列比使用多個UPDATE快。例如,查詢:

UPDATE mytable

  SET col1 = 1

      col2 = 2

      col3 = 3

  WHERE col1 <> 1

     OR col2 <> 2

     OR col3 <> 3;

比3個UPDATE語句好,因為它減少了日志記錄(盡管帶來鎖定)。

l 默認情況下,DBMS運行在自動提交模式(autocommit mode),除非被其他顯式或隱式事務重寫(或被系統設置關閉)。在這種模式下,每一條語句作為一個事務執行。如果語句執行成功,DBMS就將它提交;如果DBMS遇到錯誤,就回滾這條語句。

l 對于長的事務,可以設置稱為存儲點(savepoints)的中間標志,將事務分割為小段。存儲點允許回滾從事務當前點到事務靠前的時間點之間的變化(假定事務還沒有提交)。如果在一系列復雜的插入、更新、刪除操作未提交時,意識到最后的變化是不正確的或不必要的,使用存儲點就可以避免重新提交所有語句。Microsoft Access不支持存儲點。在Oracle、DB2、MySQL和PostgreSQL中,使用語句:

SAVEPOINT savepoint_name

對于Microsoft SQL Server,使用:

SAVE TRANSACTION savepoint_name;

查閱DBMS文檔來了解有關存儲點鎖定的細節知識及如何COMMIT或ROLLBACK到特定的存儲點。

q

 
Microsoft Access中,通過SQL視圖窗口或DAO無法執行事務,必須使用Microsoft Jet OLE DB Provider和ADO。

Oracle和DB2是隱式開始事務的。為了在Oracle 和 DB2中運行代碼14-1和代碼14-2,要刪除語句:BEGIN TRANSACTION;

為了在MySQL中運行代碼14-1和代碼14-2,將語句BEGIN TRANSACTION;變為START TRANSACTION;(或BEGIN)。

MySQL通過InnoDB和BDB表支持事務,請查閱MySQL文檔了解事務。Microsoft SQL Server、 Oracle、MySQL和PostgreSQL支持SET TRANSACTION語句設置事務特征。DB2通過服務器層和連接初始化設置控制事務特征。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲狼人综合| 亚洲欧美三级在线| 欧美日本高清| 欧美另类一区二区三区| 欧美精品videossex性护士| 欧美日韩成人一区二区| 欧美日韩在线另类| 国产精品手机视频| 国产日韩欧美一区在线| 一区二区三区在线观看欧美| 亚洲国产欧美另类丝袜| 一区二区精品在线| 午夜一区二区三区在线观看| 久久久久免费视频| 亚洲国产欧美不卡在线观看| 亚洲国产高清高潮精品美女| 一区二区三区精品视频| 欧美一级理论片| 女同性一区二区三区人了人一| 欧美日韩高清免费| 黄色av成人| 亚洲伊人伊色伊影伊综合网| 久久久久久精| 日韩一级免费观看| 久久天天狠狠| 国产精品入口尤物| 亚洲精品国精品久久99热一| 久久精品99国产精品| 亚洲国产视频一区二区| 欧美亚洲综合久久| 欧美午夜精品久久久| 尤物网精品视频| 欧美一区二区黄| 99v久久综合狠狠综合久久| 久久久久网站| 国产日韩欧美中文在线播放| 亚洲视频精选| 亚洲人成在线播放| 久久一区欧美| 激情文学一区| 久久精选视频| 午夜视频一区| 国产精品乱看| 亚洲影视在线| 夜夜嗨av一区二区三区网页| 免费国产一区二区| 久久国产精品一区二区三区四区 | 亚洲欧美日本国产有色| 免费欧美电影| 久久成人一区| 国产综合欧美在线看| 亚洲香蕉视频| 99re成人精品视频| 欧美日韩视频在线观看一区二区三区| 亚洲大胆人体视频| 免费成人网www| 久久美女艺术照精彩视频福利播放| 国产日韩久久| 久久手机免费观看| 久久精品国产999大香线蕉| 国产欧美一区二区三区在线看蜜臀 | 亚洲激情成人| 欧美成人自拍| 在线观看日韩| 欧美激情亚洲另类| 欧美二区在线| 亚洲精品欧美专区| 亚洲国产美女精品久久久久∴| 蜜桃av一区二区在线观看| 亚洲第一网站| 亚洲精品一二三区| 国产精品美女久久久久av超清| 亚洲尤物精选| 亚洲视频一区二区| 国产色视频一区| 免费成人黄色| 欧美日韩一区二区精品| 亚洲欧美日韩精品久久奇米色影视| 中日韩在线视频| 国产亚洲免费的视频看| 免费看亚洲片| 欧美性开放视频| 久久国产一二区| 美女尤物久久精品| 亚洲一区二区三区免费在线观看| 亚洲男女自偷自拍| 亚洲国产精品传媒在线观看| 99国产精品视频免费观看一公开| 国产精品午夜在线| 欧美成人在线网站| 欧美午夜一区| 欧美aa国产视频| 国产精品日韩欧美一区二区三区| 久久国产综合精品| 欧美超级免费视 在线| 亚洲欧美日韩中文播放| 久久激情一区| 亚洲你懂的在线视频| 久久久久国产精品一区| 99视频在线观看一区三区| 欧美一级在线播放| 9人人澡人人爽人人精品| 久久久久久电影| 欧美日韩高清不卡| 久热国产精品| 国产精品www色诱视频| 免费亚洲一区二区| 国产精品乱人伦一区二区| 欧美激情精品久久久久久| 国产亚洲精品bt天堂精选| 一本色道久久综合| 亚洲国产高清在线| 欧美影院在线| 羞羞答答国产精品www一本| 欧美女同视频| 亚洲国产精品久久| 狠狠狠色丁香婷婷综合久久五月| 一区二区三区四区五区视频| 亚洲精品中文字幕女同| 久久久一区二区三区| 久久爱www久久做| 国产精品国产三级国产aⅴ无密码| 亚洲国产精品一区制服丝袜| 亚洲国产福利在线| 欧美在线不卡| 久久成人免费电影| 国产精品毛片a∨一区二区三区| 最新日韩在线| 亚洲美女中文字幕| 欧美成人高清| 亚洲国产天堂久久综合网| 亚洲高清激情| 蜜臀av一级做a爰片久久| 欧美电影电视剧在线观看| 亚洲成人在线网| 欧美1区视频| 亚洲国产精选| 一本色道久久综合亚洲精品不卡| 欧美精品1区2区3区| 亚洲欧洲一区二区三区| 一区二区高清视频| 欧美日韩国产精品专区| 99在线|亚洲一区二区| 亚洲免费在线视频| 国产日韩欧美一区二区三区在线观看| 性欧美在线看片a免费观看| 久久久久久亚洲精品不卡4k岛国| 国色天香一区二区| 女主播福利一区| 亚洲最新中文字幕| 欧美伊人精品成人久久综合97| 国产乱码精品| 久久综合99re88久久爱| 亚洲人成人一区二区在线观看| 亚洲线精品一区二区三区八戒| 国产精品久久一级| 久久国产精品久久久久久电车| 美女精品在线观看| 亚洲免费电影在线| 国产精品亚洲片夜色在线| 久久国产精品亚洲va麻豆| 欧美韩日一区二区三区| 日韩视频在线观看一区二区| 欧美日韩在线播放三区四区| 亚洲欧美不卡| 欧美激情视频一区二区三区免费| 日韩午夜在线电影| 国产欧美日韩精品一区| 美日韩精品视频免费看| 99re国产精品| 欧美承认网站| 午夜精品一区二区三区在线播放| 激情欧美一区二区| 国产一区自拍视频| 欧美chengren| 亚洲摸下面视频| 亚洲国产精品免费| 国产精品久久久久久亚洲毛片| 久久国产主播| 一区二区三区四区精品| 美女网站久久| 午夜精品一区二区三区在线 | 影音国产精品| 欧美吻胸吃奶大尺度电影| 久久精品一区蜜桃臀影院| 99精品福利视频| 亚洲大胆av| 久久久欧美一区二区| 亚洲影视在线| 正在播放欧美视频| 91久久久久| 亚洲国产精品成人va在线观看| 国产精品日韩欧美一区二区三区| 欧美精品久久久久a| 久久天天躁夜夜躁狠狠躁2022| 午夜精品久久久久久久男人的天堂| 99伊人成综合| 艳女tv在线观看国产一区| 亚洲国产视频直播| 亚洲风情在线资源站|