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

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>
            伊人色综合久久天天五月婷| 欧美一级片久久久久久久| 亚洲一区二区三区在线观看视频| 亚洲国产日韩欧美在线图片| 亚洲国产天堂网精品网站| 亚洲精品网址在线观看| 亚洲另类一区二区| 99视频精品免费观看| 一区二区三区你懂的| 午夜精品一区二区三区在线播放| 欧美一级欧美一级在线播放| 美女亚洲精品| 亚洲精品国产精品国自产观看| 女女同性精品视频| 夜夜嗨av色一区二区不卡| 午夜日韩在线| 欧美精品一区二区三区蜜桃| 国产欧美精品在线| 日韩一级在线观看| 久久精品国产欧美亚洲人人爽| 亚洲国产精品精华液2区45| 亚洲图片欧美日产| 久久久午夜电影| 欧美午夜精品久久久久久超碰| 久久激情综合网| 亚洲国产美女久久久久| 亚洲一区二区精品在线| 久久久久在线观看| 日韩午夜av电影| 久久成人资源| 国产精品扒开腿做爽爽爽视频| 亚洲高清资源| 久久精品久久99精品久久| 亚洲精品乱码久久久久久蜜桃91| 亚洲专区一区二区三区| 欧美成人精品福利| 国产日韩精品久久久| 99精品视频一区二区三区| 久久中文欧美| 午夜亚洲一区| 国产精品日韩一区二区| 99国产麻豆精品| 欧美 亚欧 日韩视频在线| 欧美亚洲一区二区三区| 国产精品看片资源| 亚洲午夜伦理| 99这里只有精品| 欧美美女bb生活片| 亚洲伦伦在线| 亚洲日本成人| 老司机精品导航| 亚洲性视频h| 欧美日韩一区二区在线播放| 亚洲激情视频在线观看| 欧美成人综合一区| 久久久福利视频| 韩日欧美一区二区| 久久乐国产精品| 久久国产综合精品| 国内自拍一区| 裸体丰满少妇做受久久99精品| 久久精品人人| 亚洲国产精品va在线观看黑人| 久久免费高清视频| 久久精品夜夜夜夜久久| 1000部精品久久久久久久久| 裸体一区二区三区| 免费观看久久久4p| 99人久久精品视频最新地址| 亚洲网站在线观看| 国产亚洲欧美在线| 欧美高清视频免费观看| 欧美成人高清视频| aa级大片欧美| 亚洲视频在线免费观看| 国产精品主播| 蜜桃av一区二区| 欧美久久久久免费| 亚洲欧美另类国产| 久久久亚洲国产天美传媒修理工| 亚洲国产午夜| 亚洲网在线观看| 一区视频在线| 国产午夜精品一区理论片飘花| 久久精品国产久精国产爱| 亚洲色无码播放| 国产一区二区三区免费观看| 免费av成人在线| 欧美精品18+| 欧美在线精品一区| 久久婷婷国产麻豆91天堂| 99国产精品久久久久久久久久 | 欧美xxxx在线观看| 欧美va天堂在线| 午夜视频一区二区| 免费成人高清视频| 亚洲欧美中文另类| 另类尿喷潮videofree| 亚洲一区二区三区精品视频| 久久久999| 亚洲一区二区三区四区中文| 久久一区二区三区超碰国产精品| 在线亚洲自拍| 久久国产手机看片| 亚洲午夜精品视频| 另类亚洲自拍| 久久国产精品一区二区| 欧美激情综合五月色丁香小说| 欧美亚洲综合在线| 欧美成年视频| 毛片av中文字幕一区二区| 欧美亚男人的天堂| 欧美成人一区二区三区片免费| 欧美无砖砖区免费| 欧美成人免费全部| 国产伦精品一区二区三区照片91 | 亚洲精品少妇| 激情综合网激情| 亚洲影院在线| 亚洲一区二区三区在线视频| 噜噜噜在线观看免费视频日韩| 欧美一区二区三区男人的天堂| 欧美日韩精品免费观看视频完整 | 一本色道久久精品| 亚洲国产精品一区在线观看不卡| 亚洲图色在线| 亚洲一二三四久久| 欧美美女操人视频| 久久久久久久成人| 国产伦精品一区二区三区高清版 | 欧美日本一区二区高清播放视频| 久久噜噜亚洲综合| 国产日韩欧美成人| 亚洲综合精品自拍| 亚洲欧美成aⅴ人在线观看| 欧美精品在线视频观看| 蘑菇福利视频一区播放| 黑人中文字幕一区二区三区| 亚洲激情在线| 亚洲第一天堂av| 黄色av日韩| 久久精品国产久精国产思思| 久久精品国产2020观看福利| 国产日韩欧美制服另类| 午夜精品久久久久久久99热浪潮| 午夜欧美精品| 国产一区二区| 久久夜色精品国产| 亚洲高清二区| 夜色激情一区二区| 欧美日韩国产综合视频在线观看| 亚洲国产老妈| 日韩一区二区福利| 国产精品久久久久久久久果冻传媒 | 国产三区二区一区久久| 羞羞色国产精品| 久久久久国色av免费看影院 | 亚洲欧美一区在线| 国产欧美日韩精品a在线观看| 亚洲在线免费视频| 久久精品导航| 在线观看的日韩av| 欧美极品影院| 夜夜嗨av一区二区三区四季av| 亚洲欧美国产毛片在线| 国产色视频一区| 狼狼综合久久久久综合网| 91久久久久久| 欧美在线播放| 亚洲国产一区二区三区青草影视 | 欧美精品在线免费| 亚洲男人的天堂在线aⅴ视频| 久久全国免费视频| 一区二区三区毛片| 国产综合色在线视频区| 欧美日韩a区| 欧美亚洲免费高清在线观看| 裸体歌舞表演一区二区 | 欧美激情一区二区三区蜜桃视频 | 久久se精品一区精品二区| 欧美aa国产视频| 亚洲午夜日本在线观看| 依依成人综合视频| 国产精品成人aaaaa网站| 久久精品亚洲精品国产欧美kt∨| 亚洲区一区二区三区| 久久精品女人| 亚洲手机视频| 亚洲激情六月丁香| 国产在线一区二区三区四区 | 99re6这里只有精品| 老司机一区二区| 午夜久久久久久| 99精品欧美一区二区三区综合在线 | 久久久久久久综合| 亚洲日韩中文字幕在线播放| 久久xxxx| 亚洲视频欧洲视频| 亚洲国产精品一区二区www在线| 国产裸体写真av一区二区|