首頁 考試吧論壇 Exam8視線 考試商城 網絡課程 模擬考試 考友錄 實用文檔 求職招聘 論文下載 | ||
![]() |
2011中考 | 2011高考 | 2012考研 | 考研培訓 | 在職研 | 自學考試 | 成人高考 | 法律碩士 | MBA考試 MPA考試 | 中科院 |
|
![]() |
四六級 | 職稱英語 | 商務英語 | 公共英語 | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT 新概念英語 | 成人英語三級 | 申碩英語 | 攻碩英語 | 職稱日語 | 日語學習 | 法語 | 德語 | 韓語 |
|
![]() |
計算機等級考試 | 軟件水平考試 | 職稱計算機 | 微軟認證 | 思科認證 | Oracle認證 | Linux認證 華為認證 | Java認證 |
|
![]() |
公務員 | 報關員 | 銀行從業資格 | 證券從業資格 | 期貨從業資格 | 司法考試 | 法律顧問 | 導游資格 報檢員 | 教師資格 | 社會工作者 | 外銷員 | 國際商務師 | 跟單員 | 單證員 | 物流師 | 價格鑒證師 人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業資格 | 廣告師職業水平 駕駛員 | 網絡編輯 |
|
![]() |
衛生資格 | 執業醫師 | 執業藥師 | 執業護士 | |
![]() |
會計從業資格考試(會計證) | 經濟師 | 會計職稱 | 注冊會計師 | 審計師 | 注冊稅務師 注冊資產評估師 | 高級會計師 | ACCA | 統計師 | 精算師 | 理財規劃師 | 國際內審師 |
|
![]() |
一級建造師 | 二級建造師 | 造價工程師 | 造價員 | 咨詢工程師 | 監理工程師 | 安全工程師 質量工程師 | 物業管理師 | 招標師 | 結構工程師 | 建筑師 | 房地產估價師 | 土地估價師 | 巖土師 設備監理師 | 房地產經紀人 | 投資項目管理師 | 土地登記代理人 | 環境影響評價師 | 環保工程師 城市規劃師 | 公路監理師 | 公路造價師 | 安全評價師 | 電氣工程師 | 注冊測繪師 | 注冊計量師 |
|
![]() |
繽紛校園 | 實用文檔 | 英語學習 | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲 |
2.3 數據庫表的表示
每個數據庫在數據庫目錄中有3個文件:一個樣式(描述文件)、一個數據文件和一個索引文件。每個文件的基本名是表名,文件名擴展名代表文件類型。擴展名如下表。數據和索引文件的擴展名指出表使用老式IASM索引或新式MyISAM索引。
表 MySQL文件類型
文件類型 文件名擴展名 文件內容
樣式文件 .frm 描述表的結構(它的列、列類型、索引等)。
數據文件 .ISD(ISAM)
或.MYD(MyISAM) 包含數據文件上的所有索引的索引樹。
索引文件 .ISM(ISAM)
或.MYI(MyISAM) 該索引文件依賴表是否有索引而存在。
當你發出一條CREATE TABLE tbl_name時語句定義表的結構時,服務器創建一個名為tbl_name.frm的文件,它包括該結構的內部編碼,同時也創建一個空數據和索引文件,初始化為包含指出無記錄和無索引的信息(如果CREATE TABLE語句包括索引指定,索引文件反映出這些索引)。對應于表的文件的屬主和模式被設置為只允許MySQL服務器用戶訪問。
當你發出一條ALTER TABLE tbl_name語句時,服務器重新編碼tbl_name.frm,并修改數據和索引文件的內容以反映語句指定的結構改變。對于CREATE INDEX和DROP INDEX也是一樣,因為它們被服務器視為與ALTER TABLE等價。DROP TABLE通過刪除對應于表的三個文件來實現。
雖然你可以通過刪除數據庫目錄中對應于表的三個文件,但不能手工創建或修改一個表,如,如果my_db是當前數據庫,DROP TABLE my_tbl大概等價于下列命令。
% rm -rf DATADIR/my_db/my_tbl.*
SHOW TABLE my_db的輸出只是列出my_db數據庫目錄中的.frm文件的基文件名。有些數據庫系統一個注冊表,列舉所有包含在一個數據庫中的表,MySQL不是,因為不必要,“注冊表”隱含在數據目錄的結構中。
2.4 操作系統對數據庫和表命名的限制
MySQL對命名數據庫和表有一個原則:
名字可以由當前字符集中的任何字母數字字符組成,下劃線和美元符$也可以。
名字最長為64個字符。
然而,因為數據庫和表的名字對應于目錄和文件名,服務器運行的操作系統可能強加額外的限制。
首先,數據庫和表名僅限于對文件名合法的字符,如$在MySQL的原則中是允許的,但是如果你的操作系統不允許,則你不能在目錄或表名中使用它。實際上,這對Unix或Windows不是所擔心的,最大的難度是在執行數據庫管理時直接在shell中引用名字,例如,如果你命名一個數據庫如$my_db,包含一個美元符,任何從shell中對該名字的引用可能被shell解釋為對一個變量的引用:
%ls $my_db
my_db:undefined variable
對此,你必須轉義$字符或用引號禁止其特殊含義:
%ls \\\\$my_db
%ls $my_db
如果你用引號,一定要用單引號,而雙引號并不禁止變量解釋。
其次,雖然MySQL允許數據庫和表名最長到64個字符,但名字的長度受限于你的操作系統限定的長度,一般這不是一個問題(雖然老的System V強制14個字符)。在這種情況下,你數據庫名的上限為14個字符,而表名上限為10個字符,因為表示表的文件名有一個點(.)和三個字符的擴展名。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |