• <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>

            兔子的技術博客

            兔子

               :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            MySQL5.5以后默認使用InnoDB存儲引擎,其中InnoDB和BDB提供事務安全表,其它存儲引擎都是非事務安全表。
            若要修改默認引擎,可以修改配置文件中的default-storage-engine。可以通過:show variables like 'default_storage_engine';查看當前數(shù)據庫到默認引擎。命令:show enginesshow variables like 'have%'可以列出當前數(shù)據庫所支持到引擎。其中Value顯示為disabled的記錄表示數(shù)據庫支持此引擎,而在數(shù)據庫啟動時被禁用。在MySQL5.1以后,INFORMATION_SCHEMA數(shù)據庫中存在一個ENGINES的表,它提供的信息與show engines;語句完全一樣,可以使用下面語句來查詢哪些存儲引擎支持事物處理:select engine from information_chema.engines where transactions = 'yes';
            可以通過engine關鍵字在創(chuàng)建或修改數(shù)據庫時指定所使用到引擎。
            主要存儲引擎:MyISAM、InnoDB、MEMORY和MERGE介紹:
            在創(chuàng)建表到時候通過engine=...type=...來指定所要使用到引擎。show table status from DBname來查看指定表到引擎。

            (一)MyISAM
              
            它不支持事務,也不支持外鍵,尤其是訪問速度快,對事務完整性沒有要求或者以SELECT、INSERT為主的應用基本都可以使用這個引擎來創(chuàng)建表。
            每個MyISAM在磁盤上存儲成3個文件,其中文件名和表名都相同,但是擴展名分別為:

            • .frm(存儲表定義)
            • MYD(MYData,存儲數(shù)據)
            • MYI(MYIndex,存儲索引)

              數(shù)據文件和索引文件可以放置在不同的目錄,平均分配IO,獲取更快的速度。要指定數(shù)據文件和索引文件的路徑,需要在創(chuàng)建表的時候通過DATA DIRECTORYINDEX DIRECTORY語句指定,文件路徑需要使用絕對路徑。
              每個MyISAM表都有一個標志,服務器或myisamchk程序在檢查MyISAM數(shù)據表時會對這個標志進行設置。MyISAM表還有一個標志用來表明該數(shù)據表在上次使用后是不是被正常的關閉了。如果服務器以為當機或崩潰,這個標志可以用來判斷數(shù)據表是否需要檢查和修復。如果想讓這種檢查自動進行,可以在啟動服務器時使用--myisam-recover現(xiàn)象。這會讓服務器在每次打開一個MyISAM數(shù)據表是自動檢查數(shù)據表的標志并進行必要的修復處理。MyISAM類型的表可能會損壞,可以使用CHECK TABLE語句來檢查MyISAM表的健康,并用REPAIR TABLE語句修復一個損壞到MyISAM表。
              MyISAM的表還支持3種不同的存儲格式:

            • 靜態(tài)(固定長度)表
            • 動態(tài)表
            • 壓縮表

              其中靜態(tài)表是默認的存儲格式。靜態(tài)表中的字段都是非變長字段,這樣每個記錄都是固定長度的,這種存儲方式的優(yōu)點是存儲非常迅速,容易緩存,出現(xiàn)故障容易恢復;缺點是占用的空間通常比動態(tài)表多。靜態(tài)表在數(shù)據存儲時會根據列定義的寬度定義補足空格,但是在訪問的時候并不會得到這些空格,這些空格在返回給應用之前已經去掉。同時需要注意:在某些情況下可能需要返回字段后的空格,而使用這種格式時后面到空格會被自動處理掉。
              動態(tài)表包含變長字段,記錄不是固定長度的,這樣存儲的優(yōu)點是占用空間較少,但是頻繁到更新刪除記錄會產生碎片,需要定期執(zhí)行OPTIMIZE TABLE語句或myisamchk -r命令來改善性能,并且出現(xiàn)故障的時候恢復相對比較困難。
              壓縮表由myisamchk工具創(chuàng)建,占據非常小的空間,因為每條記錄都是被單獨壓縮的,所以只有非常小的訪問開支。 
            (二)InnoDB
              
            InnoDB存儲引擎提供了具有提交、回滾和崩潰恢復能力的事務安全。但是對比MyISAM的存儲引擎,InnoDB寫的處理效率差一些并且會占用更多的磁盤空間以保留數(shù)據和索引。
            1)自動增長列:
              
            InnoDB表的自動增長列可以手工插入,但是插入的如果是空或0,則實際插入到則是自動增長后到值。可以通過"ALTER TABLE...AUTO_INCREMENT=n;"語句強制設置自動增長值的起始值,默認為1,但是該強制到默認值是保存在內存中,數(shù)據庫重啟后該值將會丟失。可以使用LAST_INSERT_ID()查詢當前線程最后插入記錄使用的值。如果一次插入多條記錄,那么返回的是第一條記錄使用的自動增長值。
            對于InnoDB表,自動增長列必須是索引。如果是組合索引,也必須是組合索引的第一列,但是對于MyISAM表,自動增長列可以是組合索引的其他列,這樣插入記錄后,自動增長列是按照組合索引到前面幾列排序后遞增的。
            2)外鍵約束:
              
            MySQL支持外鍵的存儲引擎只有InnoDB,在創(chuàng)建外鍵的時候,父表必須有對應的索引,子表在創(chuàng)建外鍵的時候也會自動創(chuàng)建對應的索引。
                  在創(chuàng)建索引的時候,可以指定在刪除、更新父表時,對子表進行的相應操作,包括restrict、cascade、set nullno action。其中restrict和no action相同,是指限制在子表有關聯(lián)的情況下,父表不能更新;casecade表示父表在更新或刪除時,更新或者刪除子表對應的記錄;set null 則表示父表在更新或者刪除的時候,子表對應的字段被set null。
              當某個表被其它表創(chuàng)建了外鍵參照,那么該表對應的索引或主鍵被禁止刪除。
              可以使用set foreign_key_checks=0;臨時關閉外鍵約束,set foreign_key_checks=1;打開約束。
            (三)MEMORY
              
            memory使用存在內存中的內容來創(chuàng)建表。每個MEMORY表實際對應一個磁盤文件,格式是.frm。MEMORY類型的表訪問非常快,因為它到數(shù)據是放在內存中的,并且默認使用HASH索引,但是一旦服務器關閉,表中的數(shù)據就會丟失,但表還會繼續(xù)存在。
                  默認情況下,memory數(shù)據表使用散列索引,利用這種索引進行“相等比較”非常快,但是對“范圍比較”的速度就慢多了。因此,散列索引值適合使用在"="和"<=>"的操作符中,不適合使用在"<"或">"操作符中,也同樣不適合用在order by字句里。如果確實要使用"<"或">"或betwen操作符,可以使用btree索引來加快速度。
              存儲在MEMORY數(shù)據表里的數(shù)據行使用的是長度不變的格式,因此加快處理速度,這意味著不能使用BLOB和TEXT這樣的長度可變的數(shù)據類型。VARCHAR是一種長度可變的類型,但因為它在MySQL內部當作長度固定不變的CHAR類型,所以可以使用。

            create table tab_memory engine=memory select id,name,age,addr from man order by id;

              使用USING HASH/BTREE來指定特定到索引。

            create index mem_hash using hash on tab_memory(city_id);

              在啟動MySQL服務的時候使用--init-file選項,把insert into...select或load data infile 這樣的語句放入到這個文件中,就可以在服務啟動時從持久穩(wěn)固的數(shù)據源中裝載表。
              服務器需要足夠的內存來維持所在的在同一時間使用的MEMORY表,當不再使用MEMORY表時,要釋放MEMORY表所占用的內存,應該執(zhí)行DELETE FROM或truncate table或者刪除整個表。
              每個MEMORY表中放置到數(shù)據量的大小,受到max_heap_table_size系統(tǒng)變量的約束,這個系統(tǒng)變量的初始值是16M,同時在創(chuàng)建MEMORY表時可以使用MAX_ROWS子句來指定表中的最大行數(shù)。
            (四)MERGE
              
            merge存儲引擎是一組MyISAM表的組合,這些MyISAM表結構必須完全相同,MERGE表中并沒有數(shù)據,對MERGE類型的表可以進行查詢、更新、刪除的操作,這些操作實際上是對內部的MyISAM表進行操作。對于對MERGE表進行的插入操作,是根據INSERT_METHOD子句定義的插入的表,可以有3個不同的值,first和last值使得插入操作被相應的作用在第一個或最后一個表上,不定義這個子句或者為NO,表示不能對這個MERGE表進行插入操作。可以對MERGE表進行drop操作,這個操作只是刪除MERGE表的定義,對內部的表沒有任何影響。MERGE在磁盤上保留2個以MERGE表名開頭文件:.frm文件存儲表的定義;.MRG文件包含組合表的信息,包括MERGE表由哪些表組成,插入數(shù)據時的依據。可以通過修改.MRG文件來修改MERGE表,但是修改后要通過flush table刷新。

            create table man_all(id int,name varchar(20))engine=merge union=(man1,man2) insert_methos=last;

             轉自:http://www.cnblogs.com/gbyukg/archive/2011/11/09/2242271.html

            posted on 2012-04-01 11:10 會飛的兔子 閱讀(581) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據庫,MIS系統(tǒng)
            国产69精品久久久久99尤物| 久久久久亚洲AV片无码下载蜜桃 | 久久亚洲精品无码aⅴ大香| 77777亚洲午夜久久多喷| 久久免费看黄a级毛片| 久久天天躁狠狠躁夜夜不卡| 久久国产三级无码一区二区| 国内精品久久久久国产盗摄| 精品久久人人妻人人做精品| 精品国产热久久久福利| 精品久久久久中文字| 久久久久亚洲AV无码专区桃色| 人妻无码精品久久亚瑟影视| 日日狠狠久久偷偷色综合96蜜桃 | 久久人做人爽一区二区三区| 色青青草原桃花久久综合| 久久亚洲中文字幕精品一区| 一本一道久久综合狠狠老| 国产精品禁18久久久夂久| 欧美综合天天夜夜久久| 久久伊人五月天论坛| 久久亚洲sm情趣捆绑调教| 久久99精品国产麻豆| 国产精品免费看久久久香蕉| 日本加勒比久久精品| 亚洲色大成网站WWW久久九九| 国产精品99久久久久久人| 久久香蕉综合色一综合色88| 久久久久九九精品影院| 久久久久亚洲AV无码麻豆| 久久精品成人影院| 亚洲国产欧洲综合997久久| AA级片免费看视频久久| 久久精品国产久精国产一老狼| 国产91色综合久久免费| 久久人妻少妇嫩草AV蜜桃| 久久久久久久久无码精品亚洲日韩 | 99久久免费只有精品国产| 久久这里有精品| segui久久国产精品| 久久亚洲AV成人出白浆无码国产 |