MYSQL如何設(shè)置大小寫(xiě)敏感?
平時(shí)很少會(huì)考慮數(shù)據(jù)存儲(chǔ)需要明確字符串類(lèi)型字段的大小寫(xiě),MYSQL默認(rèn)的查詢(xún)也不區(qū)分大小寫(xiě)。但作為用戶(hù)信息,一旦用戶(hù)名重復(fù),又會(huì)浪費(fèi)很多資源。再者,李逵、李鬼的多起來(lái),偵辨起來(lái)很困難。要做到這一點(diǎn),要么在建表時(shí),明確大小寫(xiě)敏感(字段明確大小寫(xiě)敏感)。如果通盤(pán)數(shù)據(jù)庫(kù)所有字段都需要大小寫(xiě)敏感,不如在字符集設(shè)置時(shí)做好調(diào)整。不過(guò),通常不建議這么做。
如果跟我一樣,數(shù)據(jù)庫(kù)已經(jīng)在線(xiàn)上跑了,一個(gè)表上百萬(wàn)條數(shù)據(jù),做字段類(lèi)型變更有可能導(dǎo)致數(shù)據(jù)庫(kù)宕機(jī)。那么好吧,在查詢(xún)時(shí),多加個(gè)單詞好了!-
例如,一般查詢(xún):
SELECT*FROMUWHEREnameLIKE'a%';
SELECT*FROMUWHEREnameLIKE'A%';
其結(jié)果是一樣的,為了區(qū)分'A%'和'a%',可以這么做:
SELECT*FROMUWHEREbinarynameLIKE'a%';
SELECT*FROMUWHEREbinarynameLIKE'A%';
僅僅多了一個(gè)binary,就可以得到不同的結(jié)果!
當(dāng)然,如果需要建表時(shí)強(qiáng)制區(qū)分大小寫(xiě),可以這么寫(xiě):
createtabletable_name(
就這么簡(jiǎn)單!