mysql建表時(shí)強(qiáng)制區(qū)分大小寫(xiě)怎么寫(xiě)?
平時(shí)很少會(huì)考慮數(shù)據(jù)存儲(chǔ)需要明確字符串類(lèi)型字段的大小寫(xiě),MySQL默認(rèn)的查詢也不區(qū)分大小寫(xiě)。但作為用戶信息,一旦用戶名重復(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)在線上跑了,一個(gè)表上百萬(wàn)條數(shù)據(jù),做字段類(lèi)型變更有可能導(dǎo)致數(shù)據(jù)庫(kù)宕機(jī)。那么好吧,在查詢時(shí),多加個(gè)單詞好了!-
例如,一般查詢:
SELECT * FROM U WHERE name LIKE 'a%';
SELECT * FROM U WHERE name LIKE 'A%';
其結(jié)果是一樣的,為了區(qū)分'A%'和'a%',可以這么做:
SELECT * FROM U WHERE binary name LIKE 'a%';
SELECT * FROM U WHERE binary name LIKE 'A%';
僅僅多了一個(gè)binary,就可以得到不同的結(jié)果!
當(dāng)然,如果需要建表時(shí)強(qiáng)制區(qū)分大小寫(xiě),可以這么寫(xiě):
create table table_name(
name varchar (20) binary
);
就這么簡(jiǎn)單!
關(guān)鍵詞:mysql
閱讀本文后您有什么感想? 已有 人給出評(píng)價(jià)!
- 0
- 0
- 0
- 0
- 0
- 0