MySql查詢不區(qū)分大小寫解決方案(兩種)
當(dāng)我們輸入不管大小寫都能查詢到數(shù)據(jù),例如:輸入 aaa 或者aaA ,AAA都能查詢同樣的結(jié)果,說明查詢條件對(duì)大小寫不敏感。
解決方案一:
于是懷疑Mysql的問題。做個(gè)實(shí)驗(yàn):直接使用客戶端用sql查詢數(shù)據(jù)庫(kù)。 發(fā)現(xiàn)的確是大小不敏感 。
通過查詢資料發(fā)現(xiàn)需要設(shè)置collate(校對(duì)) 。 collate規(guī)則:
*_bin: 表示的是binary case sensitive collation,也就是說是區(qū)分大小寫的
*_cs: case sensitive collation,區(qū)分大小寫
*_ci: case insensitive collation,不區(qū)分大小寫
解決方法。
1.可以將查詢條件用binary()括起來。 比如:
select * from TableA where binary columnA ='aaa';
2. 可以修改該字段的collation 為 binary
比如:
ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL;
解決方案二:
mysql查詢默認(rèn)是不區(qū)分大小寫的 如:
select * from some_table where str=‘a(chǎn)bc'; select * from some_table where str='ABC';
得到的結(jié)果是一樣的,如果我們需要進(jìn)行區(qū)分的話可以按照如下方法來做:
第一種方法:
要讓mysql查詢區(qū)分大小寫,可以:
select * from some_table where binary str='abc' select * from some_table where binary str='ABC'
第二方法:
在建表時(shí)時(shí)候加以標(biāo)識(shí)
create table some_table( str char(20) binary )
原理:
對(duì)于CHAR、VARCHAR和TEXT類型,BINARY屬性可以為列分配該列字符集的 校對(duì)規(guī)則。BINARY屬性是指定列字符集的二元 校對(duì)規(guī)則的簡(jiǎn)寫。排序和比較基于數(shù)值字符值。因此也就自然區(qū)分了大小寫。
以上通過兩種方案解決了MySql查詢不區(qū)分大小寫的問題,希望對(duì)大家有所幫助,更多有mysql數(shù)據(jù)查詢問題,請(qǐng)登錄本站學(xué)習(xí)。
相關(guān)文章
SQL Server自動(dòng)生成日期加數(shù)字的序列號(hào)
需要生成下面的序列號(hào),前半部分是yyyymmdd格式的年月日時(shí)間數(shù)字,后半部分則是每天都從1順序增長(zhǎng)的數(shù)字,位數(shù)要固定,中間不足的補(bǔ)0。2009-08-08
Zabbix監(jiān)控SQL Server服務(wù)狀態(tài)的方法詳解
這篇文章主要給大家介紹了關(guān)于Zabbix監(jiān)控SQL Server服務(wù)狀態(tài)的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
sqlserver 2000 遠(yuǎn)程連接 服務(wù)器的解決方案
在連接本地服務(wù)器時(shí),通常使用的是命名管道協(xié)議(在服務(wù)器網(wǎng)絡(luò)實(shí)用工具里可以看到啟用的協(xié)議有這個(gè)2009-06-06
idea連接sql?sever2019圖文教程(超詳細(xì))
這篇文章主要介紹了idea連接sql?sever2019的圖文教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04
SQLServer 2008數(shù)據(jù)庫(kù)降級(jí)到2005低版本
SQLServer 2008R2備份的數(shù)據(jù)庫(kù)還原到2008上面時(shí)報(bào)錯(cuò)引發(fā)的思考,如何把SQLServer數(shù)據(jù)庫(kù)從高版本降級(jí)到低版本?本文為大家解答2016-11-11
淺析SQL Server的分頁(yè)方式 ISNULL與COALESCE性能比較
本文上述重點(diǎn)講述了SQL Server的分頁(yè)方式,COALESCE和ISNULL函數(shù)區(qū)別之處,簡(jiǎn)短的內(nèi)容,深入的理解。有興趣的朋友可以看下2016-12-12
mssqlserver恢復(fù)ldf文件數(shù)據(jù)的方法
本文介紹mssqlserver怎么恢復(fù)ldf文件數(shù)據(jù)庫(kù),簡(jiǎn)單的來說,MDF文件是SQL server用來存放數(shù)據(jù)的數(shù)據(jù)庫(kù)文件;LDF文件SQL server是日志文件,存放了對(duì)數(shù)據(jù)庫(kù)進(jìn)行的所有操作信息2013-11-11

