在插入表的時(shí)候使用mysql函數(shù)強(qiáng)制轉(zhuǎn)成小寫即可:
創(chuàng)新互聯(lián)公司專注于企業(yè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、祿勸網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5場(chǎng)景定制、電子商務(wù)商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)公司、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為祿勸等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
MySQL字符串大小寫轉(zhuǎn)換需要用到MySQL字符串大小寫轉(zhuǎn)換函數(shù),MySQL 字符串大小寫轉(zhuǎn)化函數(shù)有兩對(duì): lower()和 lcase(), uppper() 和 ucase():
mysql select lower('DDD');
+--------------+
| lower('DDD') |
+--------------+
| ddd |
+--------------+
mysql select lcase('DDD');
+--------------+
| lcase('DDD') |
+--------------+
| ddd |
+--------------+
如何查看mysql數(shù)據(jù)表是否區(qū)分大小寫?
答:mysql是否區(qū)分大小寫,可以使用show Variables like '%table_names'查看lower_case_table_names的值,0代表區(qū)分,1代表不區(qū)分。
如何讓mysql數(shù)據(jù)表內(nèi)的varchar字段區(qū)分大小寫?
mysql對(duì)于類型為varchar數(shù)據(jù)默認(rèn)不區(qū)分大小寫,但如果該字段以“*_bin”編碼的話會(huì)使mysql對(duì)其區(qū)分大小寫。
Mysql的字段大小寫默認(rèn)策略是什么?
mysql對(duì)于字段名的策略與varchar類型數(shù)據(jù)相同。即:默認(rèn)不區(qū)分大小寫,但如果該字段是以“*_bin”編碼的話會(huì)使mysql對(duì)其區(qū)分大小寫。
Mysql的數(shù)據(jù)表區(qū)分大小寫的默認(rèn)策略是什么?
mysql對(duì)于表名的策略與varchar類型數(shù)據(jù)相同。即:默認(rèn)不區(qū)分大小寫,但如果該表是以“*_bin”編碼的話會(huì)使mysql對(duì)其區(qū)分大小寫。
如何修改mysql(mysql.conf)配置來(lái)更改大小寫默認(rèn)值?
如果按照第一項(xiàng)查看lower_case_table_names的值為0,但需要讓mysql默認(rèn)不區(qū)分大小寫的話,需要在mysql配置文件中添加參數(shù)并重啟mysql數(shù)據(jù)庫(kù)。mysql配置文件的修改內(nèi)容如下:
[mysqld]
...
lower_case_table_names = 1
注意:表和字段的編碼盡量繼承數(shù)據(jù)庫(kù)的編碼(不明顯指定即繼承),以免引起混亂。
LINUX下的MYSQL默認(rèn)是要區(qū)分表名大小寫的 ,而在windows下表名不區(qū)分大小寫
讓MYSQL不區(qū)分表名大小寫的方法其實(shí)很簡(jiǎn)單:
1.用ROOT登錄,修改/etc/my.cnf
2.在[mysqld]下加入一行:lower_case_table_names=1
3.重新啟動(dòng)數(shù)據(jù)庫(kù)即可
以我的windows環(huán)境為例: 在my.ini [mysqld]下面增加 lower_case_table_names=0 就可以新建大寫表名的表了 也可以rename table 表名 to 新表名 去改現(xiàn)有的表 改時(shí)注意 要先改成一個(gè)不存在的表 再改回全部大寫的表 比如你要把test改成TEST 先rena
剛開始使用 mysql 的時(shí)候,剛開始是想要區(qū)分列名大小寫的問(wèn)題,在網(wǎng)上看到很多辦法, 于是就 1、 linux 下 mysql 安裝完后是默認(rèn):區(qū)分表名的大小寫,不區(qū)分列名的大小寫; 2、 2、 root 帳號(hào)登錄后, 用 在/etc/my.cnf 中的[mysqld]后添加添加 lower_case_table_names=1, 重啟 MYSQL 服務(wù),這時(shí)已設(shè)置成功:不區(qū)分表名的大小寫; lower_case_table_names 參數(shù)詳解: lower_case_table_names = 0 其中 0:區(qū)分大小寫,1:不區(qū)分大小寫 MySQL 在 Linux 下數(shù)據(jù)庫(kù)名、表名、列名、別名大小寫規(guī)則是這樣的: 1、數(shù)據(jù)庫(kù)名與表名是嚴(yán)格區(qū)分大小寫的; 2、表的別名是嚴(yán)格區(qū)分大小寫的; 3、列名與列的別名在所有的情況下均是忽略大小寫的; 4、變量名也是嚴(yán)格區(qū)分大小寫的; MySQL 在 Windows 下都不區(qū)分大小寫。 在 my.ini 中的[mysqld]后添加添加 lower_case_table_names=1,重啟 MYSQL 服務(wù), 這時(shí)已設(shè)置成功:不區(qū)分表名的大小寫; lower_case_table_names 參數(shù)詳解: lower_case_table_names = 0 其中 0:區(qū)分大小寫,1:不區(qū)分大小寫 3、如果想在查詢時(shí)區(qū)分字段值的大小寫,則:字段值需要設(shè)置 BINARY 屬性,設(shè)置的方 法有多種: A、 創(chuàng)建時(shí)設(shè)置: CREATE TABLE T( A VARCHAR(10) BINARY ); B、 使用 alter 修改: ALTER TABLE `tablename` MODIFY COLUMN `cloname` VARCHAR(45) BINARY; C、mysql table editor 中直接勾選 BINARY 項(xiàng)。 亂碼解決,更詳細(xì)的看下字符集設(shè)置這篇 在[mysqld] 下增加下句 default-character-set=utf8 但是經(jīng)過(guò)本人的實(shí)踐之后如果按此方法修改后表名的區(qū)分大小寫指的是你創(chuàng)建一 個(gè)表之后,它保留你創(chuàng)建時(shí)候的表名的原貌,但是在系統(tǒng)后臺(tái)存儲(chǔ)的時(shí)候此表是不 區(qū)分大小寫的,也就是說(shuō)在創(chuàng)建一個(gè)表名僅大小寫不一樣的表是不可以的。 例如; 在修改為表名區(qū)分大小寫之后,也就是 lower_case_table_names = 0 (不管是在哪個(gè)系 統(tǒng)下)在 mysql 命令行界面下輸入 CREATE TABLE TEST ( Id int not null primary key, Name varchar not null ); 之后你執(zhí)行 show tables; 會(huì)包含一個(gè) TEST 表,表名保留原來(lái)的大小寫, 你如果輸入 show tables like ‘t%’;是查不到這個(gè)新建的表的; 之后你在創(chuàng)建另外一個(gè)表, CREATE TABLE test ( Id int not null primary key, Name varchar not null ); 系統(tǒng)會(huì)提示你,表 test 已經(jīng)存在,不允許創(chuàng)建。
select * from abc whre id="a" 與
select * from abc whre id="A" 查詢出的結(jié)果是不同的
對(duì)單個(gè)字段設(shè)置的方式就不用說(shuō)了,希望得到是對(duì)mysql默認(rèn)的設(shè)置或是對(duì)整個(gè)庫(kù)的設(shè)置
是否區(qū)分大小寫和校對(duì)規(guī)則有關(guān),默認(rèn)設(shè)的規(guī)則是大小寫不敏感的。
show create table如果看到collate是ci結(jié)尾,那么就是不區(qū)別的,如果cs或bin結(jié)尾,就是區(qū)別的。
如果建表的時(shí)候選擇的是區(qū)別大小寫的規(guī)則而查詢的時(shí)候又暫時(shí)不想?yún)^(qū)別,
可以用類似
WHERE column_name COLLATE latin1_general_ci = 'xxx'
的寫法改變查詢使用的校對(duì)規(guī)則