MySQL資料庫中庫、表名、欄位的大小寫問題
在使用MySQL建庫的過程中發現了一個問題,無論怎麼建立庫,創建出來的庫名都是小寫的。然後上網查了一下資料。
在MySQL中,資料庫和表都是對應目錄下的一個或多個檔案。因此,作業系統的大小寫是否敏感決定了資料庫大小寫是否敏感。而在Windows中是對大小寫不敏感的(Linux是對大小寫敏感的)。
下圖是在windows作業系統上MySQL中lower_case_table_system和lower_case_table_names的預設值。
下圖是在Linux作業系統上MySQL中lower_case_table_system和lower_case_table_names的預設值。
變數lower_case_file_system說明是否資料目錄所在的檔案系統對檔名的大小寫敏感。ON說明檔名的大小寫不敏感,OFF表示敏感。
lower_case_table_names引數說明
當值為0時
使用CREATE TABLE或CREATE DATABASE語句制定的大小寫字母在硬碟上儲存表名和資料庫名。名稱比較對大小寫敏感。在大小寫不敏感的作業系統如windows
或Max OS x上我們不能將引數設為0,如果再大小寫不敏感的檔案系統上將“lower_case_table_names”強制設定為0,並使用不同的大小寫訪問MyISAM表名,可能會導
致索引破壞。
當值為1時
表名在硬碟上以小寫儲存,名稱比較對大小寫不敏感。MySQL將所有表名轉換為小寫儲存和查詢表上。該行為也適合資料庫名和表的別名,該值為Windows的預設值。
當值為2時
表名和資料庫名在硬碟上使用CREATETABLE或CREATE DATABASE語句指定的大小寫字母進行儲存,但MySQL將它們轉換為小寫在查詢表上。名稱比較對大小寫不
敏感,即按照大小寫來儲存,按照小寫來比較。注意:只在對大小寫不敏感的檔案系統上適用!innodb表名用小寫儲存。
那麼現在問題來了,如何將Linux作業系統上有大小寫的資料庫還原到Windows作業系統上?
1、 將資料庫資料通過mysqldump匯出
2、 在my.cnf或my.ini中更改lower_case_tables_name=1,並重啟Mysql服務。
3、 將匯出的資料匯入MySQL資料庫中。
在MySql上為了避免大小寫問題引來的不必要的麻煩,建議都將“lower_case_tables_name”設定值為1。我們可以用其他的方式來命名。