CentOS下無法正常獲取MySQL數據庫表數據的問題
目前技術框架使用JSF(richfaces、facelets)+Spring+JPA(OpenJPA),不使用數據庫依賴的觸發(fā)器或存儲過程,所有業(yè)務邏輯在web服務器上執(zhí)行,因此數據庫基本不用考慮移植問題。但是本來在windows下運行正常的系統(tǒng),在linux下卻沒法獲取一些表的內容。由于數據庫的初始化,最初只是體現在幾個需要手工維護的表數據上,最終卻發(fā)現原來是因為數據庫表名大小寫的問題!
具體操作過程:
1、在windows下,使用MySQL的客戶端工具“Navicat”,將當前的數據庫導出到test.sql文件中。說明:導出的.sql文件中,所有的表名都是小寫。
2、將導出的.sql文件拷貝至linux下,導入需要使用的數據庫中
3、啟動web服務器,訪問服務。問題出現:許多表無法訪問。
4、在mysql中使用“show tables;”命令,發(fā)現表名有重復,重復的表名區(qū)別在于大小寫,大寫的表名與對應的實體bean名相同。找到問題:表名大小寫造成的數據無法訪問。 (linux 下的 MySQL 安裝完后,默認區(qū)分表名的大小寫,不區(qū)分列名的大小寫;Windows下默認不區(qū)分大小寫 )
上述問題有兩種解決方案:
● 在JPA的實體bean的聲明中,使用“Table”的“name”屬性,指定表名,表名盡量全部使用小寫,不同單詞之間使用下劃線連接
例如:
@Table(name="sys_user") |
● 使用Linux下MySQL的相關參數,使MySQL不區(qū)分大小寫( lower_case_table_names=1 )
上述兩種方法,第一種是較為通用的解決方案,但是需要開發(fā)人員更改全部的實體bean,然后重新編譯;第二種方案適合于系統(tǒng)已經進入生產環(huán)境的狀況,并且對如何修改linux下的MySQL配置需要一定的專業(yè)知識及經驗,對實施人員技術要求較高。
關于如何修改CentOS下的MySQL不區(qū)分大小寫的具體操作方法:
用 root 帳號登錄后,在 /etc/my.cnf 中的 [mysqld] 后添加添加 lower_case_table_names=1 ,重啟Mysqld 服務。服務重新啟動之后,已設置成功:不區(qū)分表名的大小寫
關于lower_case_table_names 參數詳解: lower_case_table_names參數有兩個值:[0、1 ]其中0 :區(qū)分大小寫,1 :不區(qū)分大小寫
補充說明:
關于持久層,使用Spring自動生成的DDL來創(chuàng)建對應的持久層數據庫表及索引等數據,簡化實施工作的復雜度