MySQL從正則查詢扯到查詢中的大小寫敏感的解決方法,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)建站主營城東網站建設的網絡公司,主營網站建設方案,重慶APP軟件開發(fā),城東h5成都小程序開發(fā)搭建,城東網站營銷推廣歡迎城東等地區(qū)企業(yè)咨詢
MYSQL 中的查詢給人的觀念大多是簡單的,不復雜的,將復雜的事情都交給程序來做,數(shù)據(jù)庫就是一個容器的概念或一個固化的觀念。
其實隨著MYSQL8 的到來,越來越多以前不能在SQL 端執(zhí)行的語句,可以在MYSQL中執(zhí)行,例如CTE ,窗口函數(shù),等等,而查詢中有的是使用like來查,而LIKE 的查詢中有一些查詢比較復雜,而正則表達式在SQL 查詢中的使用可以幫助一些復雜查詢的表達和實現(xiàn)??偨Y起來,MYSQL 正在從街邊的小屁孩,變成那個拒絕鋼鐵俠出席會議的蜘蛛俠。(如果你最近看了MYSQL 8.017 的那個版本的變化)
怎么能進行這樣的查詢,我們來看下面幾個例子
1 如我們要查詢 employees 表中 first_name 是 G 開頭的名字的人有多少
這里我們可以使用 Rlike 來操作 正則表達式
select count(*) from employees where first_name RLIKE '^G';
這里G 開頭的 first_name 的人有 1萬6千多人
下面有一個需求,想找到 G 大小開頭的,中間是字母的 結尾是 i 的 firstname
下面的語句應該能滿足你的需求
select * from employees where first_name RLIKE '^G[a-z]' and first_name RLIKE 'i$'
3 查詢 G 開頭 uo 在 第二第三 字符位置的 first_name
select * from employees where first_name RLIKE '^G[uo]{2,3}';
4 而實際當中面臨的一些問題,有的時候也需要使用正則表達式來解決
例如 下圖,我們遇到 first_name 寫法有些怪異但如果按照平時的查詢的方法,會將他們一股腦的都查詢出來
select * from employees where first_name = 'georgi';
我們使用上面的語句來查詢,結果可想而知,會不區(qū)分大小寫來將所有的Georgi gEORGI 都查出來
其實在早期的MYSQL 的版本 5.X 之前 正則表達式是可以區(qū)分大小寫的
但現(xiàn)在的版本是不能區(qū)分的。
如何讓目前的正則表達式能區(qū)分出大小寫
我們可以在 你要查詢的字段名前加上 binary 然后匹配正常的正則,你就可以查到你要查的數(shù)據(jù)了,請見上圖
那么問題來了,題目說扯到大小寫敏感,你上面那個能算是扯到大小寫敏感嗎,如果我不用正則表達式,或者我不愿意在字段前面加binary ,你怎么解決我大小寫敏感的問題。
說扯咱們就扯,直接跳到療效,看我下邊沒有使用 binary喲,照樣扯到,不不不 是查到了 數(shù)據(jù)。
不用正則也可以
有人可能馬上說,你表里就那一條記錄吧,來看下圖,當然不是
問題就扯出來了,到底我搞了什么,讓MYSQL first_name 大小寫敏感了
答案就在圖里面,修改字段后面加binary 就可以了
好的今天就扯到這里。
關于MYSQL從正則查詢扯到查詢中的大小寫敏感的解決方法問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關知識。
文章名稱:MYSQL從正則查詢扯到查詢中的大小寫敏感的解決方法
轉載來源:http://bm7419.com/article16/jcgodg.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供微信小程序、品牌網站制作、電子商務、App設計、網頁設計公司、App開發(fā)
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)