您好,登錄后才能下訂單哦!
MYSQL從正則查詢扯到查詢中的大小寫敏感的解決方法,針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
MYSQL 中的查詢給人的觀念大多是簡(jiǎn)單的,不復(fù)雜的,將復(fù)雜的事情都交給程序來(lái)做,數(shù)據(jù)庫(kù)就是一個(gè)容器的概念或一個(gè)固化的觀念。
其實(shí)隨著MYSQL8 的到來(lái),越來(lái)越多以前不能在SQL 端執(zhí)行的語(yǔ)句,可以在MYSQL中執(zhí)行,例如CTE ,窗口函數(shù),等等,而查詢中有的是使用like來(lái)查,而LIKE 的查詢中有一些查詢比較復(fù)雜,而正則表達(dá)式在SQL 查詢中的使用可以幫助一些復(fù)雜查詢的表達(dá)和實(shí)現(xiàn)??偨Y(jié)起來(lái),MYSQL 正在從街邊的小屁孩,變成那個(gè)拒絕鋼鐵俠出席會(huì)議的蜘蛛俠。(如果你最近看了MYSQL 8.017 的那個(gè)版本的變化)
怎么能進(jìn)行這樣的查詢,我們來(lái)看下面幾個(gè)例子
1 如我們要查詢 employees 表中 first_name 是 G 開(kāi)頭的名字的人有多少
這里我們可以使用 Rlike 來(lái)操作 正則表達(dá)式
select count(*) from employees where first_name RLIKE '^G';
這里G 開(kāi)頭的 first_name 的人有 1萬(wàn)6千多人
下面有一個(gè)需求,想找到 G 大小開(kāi)頭的,中間是字母的 結(jié)尾是 i 的 firstname
下面的語(yǔ)句應(yīng)該能滿足你的需求
select * from employees where first_name RLIKE '^G[a-z]' and first_name RLIKE 'i$'
3 查詢 G 開(kāi)頭 uo 在 第二第三 字符位置的 first_name
select * from employees where first_name RLIKE '^G[uo]{2,3}';
4 而實(shí)際當(dāng)中面臨的一些問(wèn)題,有的時(shí)候也需要使用正則表達(dá)式來(lái)解決
例如 下圖,我們遇到 first_name 寫法有些怪異但如果按照平時(shí)的查詢的方法,會(huì)將他們一股腦的都查詢出來(lái)
select * from employees where first_name = 'georgi';
我們使用上面的語(yǔ)句來(lái)查詢,結(jié)果可想而知,會(huì)不區(qū)分大小寫來(lái)將所有的Georgi gEORGI 都查出來(lái)
其實(shí)在早期的MYSQL 的版本 5.X 之前 正則表達(dá)式是可以區(qū)分大小寫的
但現(xiàn)在的版本是不能區(qū)分的。
如何讓目前的正則表達(dá)式能區(qū)分出大小寫
我們可以在 你要查詢的字段名前加上 binary 然后匹配正常的正則,你就可以查到你要查的數(shù)據(jù)了,請(qǐng)見(jiàn)上圖
那么問(wèn)題來(lái)了,題目說(shuō)扯到大小寫敏感,你上面那個(gè)能算是扯到大小寫敏感嗎,如果我不用正則表達(dá)式,或者我不愿意在字段前面加binary ,你怎么解決我大小寫敏感的問(wèn)題。
說(shuō)扯咱們就扯,直接跳到療效,看我下邊沒(méi)有使用 binary喲,照樣扯到,不不不 是查到了 數(shù)據(jù)。
不用正則也可以
有人可能馬上說(shuō),你表里就那一條記錄吧,來(lái)看下圖,當(dāng)然不是
問(wèn)題就扯出來(lái)了,到底我搞了什么,讓MYSQL first_name 大小寫敏感了
答案就在圖里面,修改字段后面加binary 就可以了
好的今天就扯到這里。
關(guān)于MYSQL從正則查詢扯到查詢中的大小寫敏感的解決方法問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。