欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文帶你了解如何用MySQL通配符實(shí)現(xiàn)過濾功能

 更新時(shí)間:2023年07月18日 09:55:28   作者:M malloc  
本文章將介紹什么是通配符、如何使用通配符以及怎樣使用LIKE操作符進(jìn)行通配搜索,以便對(duì)數(shù)據(jù)進(jìn)行復(fù)雜過濾,感興趣的小伙伴跟著小編一起來學(xué)習(xí)吧

LIKE操作符

通配符(wildcard)

通配符 (wildcard) 用來匹配值的一部分的特殊字符

搜索模式(search pattern)

搜索模式(search pattern) 由字面值、通配符或兩者組合構(gòu)成的搜索條件。

深入分析

通配符本身實(shí)際是SQL的WHERE子中有特殊含義的字符,SQL支持幾種通配符。

為在搜索子句中使用通配符,必須使用LIKE操作符。LIKE指示MySQL后跟的搜索模式利用通配符匹配而不是直接相等匹配進(jìn)行比較。

謂詞

謂詞操作符何時(shí)不是操作符?答案是在它作為謂詞(predicate)時(shí)。從技術(shù)上說,LIKE是謂詞而不是操作符。雖然最終的結(jié)果是相同的,但應(yīng)該對(duì)此術(shù)語有所了解,以免在SQL文檔中遇到此術(shù)語時(shí)不知道

百分號(hào)(%)通配符

提示

最常使用的通配符是百分號(hào)(%)。在搜索串中,%表示任何字符出現(xiàn)任意次數(shù)。例如,為了找出所有以詞jet起頭的產(chǎn)品,可使用以下SELECT語句:

輸入

SELECT prod_id,prod_name FROM products
	WHERE prod_name LIKE 'jet%';

輸出

分析

此例子使用了搜索模式 ‘jet%’。在執(zhí)行這條子句時(shí),將檢索任意以jet起頭的詞。%告訴MySQL接受jet之后的任意字符,不管它有多少字符。

注意區(qū)分大小寫

區(qū)分大小寫 根據(jù)MySQL的配置方式,搜索可以是區(qū)分大小寫的。如果區(qū)分大小寫,'jet%'與JetPack 1000將不匹配

例子精講

通配符可在搜索模式中任意位置使用,并且可以使用多個(gè)通配符下面的例子使用兩個(gè)通配符,它們位于模式的兩端:

輸入

SELECT prod_id,prod_name FROM products
	WHERE prod_name LIKE 'anvil%';

輸出

分析

搜索模式%anvil%表示匹配任何位置包含文本anvil的值,而不論它之前或之后出現(xiàn)什么字符。

通配符也可以出現(xiàn)在搜索模式的中間,雖然這樣做不太有用。下面的例子找出以s起頭以e結(jié)尾的所有產(chǎn)品:

輸入

SELECT prod_name FROM products
	WHERE prod_name LIKE 's%e';

分析

重要的是要注意到,除了一個(gè)或多個(gè)字符外,還能匹配0個(gè)字符。%代表搜索模式中給定位置的0個(gè)、1個(gè)或多個(gè)字符

注意尾空格

注意尾空格 尾空格可能會(huì)干擾通配符匹配。例如,在保存詞anvil時(shí),如果它后面有一個(gè)或多個(gè)空格,則子句WHERE prod_name LIKE ‘%anvil’ 將不會(huì)匹配它們,因?yàn)樵谧詈蟮?后有多余的字符。解決這個(gè)問題的一個(gè)簡單的辦法是在搜索模式最后附加一個(gè)%。一個(gè)更好的辦法是使用函數(shù)(在后面的章節(jié)會(huì)介紹)去掉首尾空格

注意NULL

注意NULL 雖然似乎%通配符可以匹配任何東西,但有一個(gè)例外,即NULL。即使是WHERE prod_name LIKE%也不能匹配用值NULL作為產(chǎn)品名的行

下劃線(_)通配符

概要

另一個(gè)有用的通配符是下劃線(_)。下劃線的用途與%一樣,但下劃線只匹配單個(gè)字符而不是多個(gè)字符。

舉例分析

輸入

SELECT prod_id, prod_name FROM products
	WHERE prod_name LIKE '_ ton anvil';

輸出

分析

此WHERE子句中的搜索模式給出了后面跟有文本的兩個(gè)通配符。結(jié)果只顯示匹配搜索模式的行:第一行中下劃線匹配1,第二行中匹配2。.5 ton anvil產(chǎn)品沒有匹配,因?yàn)樗阉髂J揭笃ヅ鋬蓚€(gè)通配符而不是一個(gè)。對(duì)照一下,下面的SELECT語句使用%通配符,

返回三行產(chǎn)品:

SELECT prod_id,prod_name FROM products
	WHERE prod_name LIKE '% ton anvil';

輸出

注意

與%能匹配0個(gè)字符不一樣, 總是匹配一個(gè)字符,不能多也不能少。

理論概述

  • 不要過度使用通配符。如果其他操作符能達(dá)到相同的目的,應(yīng)該使用其他操作符。
  • 在確實(shí)需要使用通配符時(shí),除非絕對(duì)有必要,否則不要把它們用在搜索模式的開始處。把通配符置于搜索模式的開始處,搜索起來是最慢的。
  • 仔細(xì)注意通配符的位置。如果放錯(cuò)地方,可能不會(huì)返回想要的數(shù)據(jù)

如何鞏固學(xué)習(xí)

提示:在學(xué)習(xí)的過程中,我們需要先自行進(jìn)行思考,而不是一遇到不會(huì)的就放棄思考直接看答案,如果最后遇到真的不會(huì)的題目,我們可以適當(dāng)?shù)倪M(jìn)行觀看答案,看自己的思路是否正確,在作出正確的判斷

本文小結(jié)

本文章介紹了什么是通配符以及如何在WHERE子句中使用SQL通配符并且還說明了通配符應(yīng)該細(xì)心使用,不要過度使用。

到此這篇關(guān)于一文帶你了解如何用MySQL通配符實(shí)現(xiàn)過濾功能的文章就介紹到這了,更多相關(guān)MySQL通配符過濾內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL數(shù)字的取整、四舍五入、保留n位小數(shù)方式

    MySQL數(shù)字的取整、四舍五入、保留n位小數(shù)方式

    這篇文章主要介紹了MySQL數(shù)字的取整、四舍五入、保留n位小數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • MySQL 搭建MHA架構(gòu)部署的步驟

    MySQL 搭建MHA架構(gòu)部署的步驟

    這篇文章主要介紹了MySQL 搭建MHA架構(gòu)部署的步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • MySQL實(shí)現(xiàn)索引下推的示例代碼

    MySQL實(shí)現(xiàn)索引下推的示例代碼

    索引下推是一種數(shù)據(jù)庫查詢優(yōu)化技術(shù),通過在索引掃描階段應(yīng)用過濾條件,減少回表操作,本文主要介紹了MySQL實(shí)現(xiàn)索引下推的示例代碼,感興趣的可以了解一下
    2025-02-02
  • Ubuntu上mysql的安裝及使用(通用版)

    Ubuntu上mysql的安裝及使用(通用版)

    今天小編就為大家分享一篇關(guān)于Ubuntu上mysql的安裝及使用(通用版),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • mysql中cast函數(shù)用法小結(jié)

    mysql中cast函數(shù)用法小結(jié)

    在MySQL中,CAST函數(shù)用于將一個(gè)表達(dá)式轉(zhuǎn)換為指定的數(shù)據(jù)類型,本文主要介紹了mysql中cast函數(shù)用法小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • 出現(xiàn)錯(cuò)誤mysql Table ''performance_schema...解決辦法

    出現(xiàn)錯(cuò)誤mysql Table ''performance_schema...解決辦法

    這篇文章主要介紹了解決出現(xiàn)錯(cuò)誤mysql Table 'performance_schema.session_variables' doesn't exist的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • Window中MySQL繞過密碼登錄的底層原理詳解

    Window中MySQL繞過密碼登錄的底層原理詳解

    在 MySQL 中,root 用戶的密碼存儲(chǔ)和認(rèn)證機(jī)制隨著版本的升級(jí)發(fā)生了變化,繞過密碼登錄主要依賴于 --skip-grant-tables 選項(xiàng),本文將詳細(xì)分析 MySQL 繞過密碼的底層原理,并解釋為什么某些操作在 --skip-grant-tables 模式下無效,以及如何正確生效修改
    2025-02-02
  • mysql 帶多個(gè)條件的查詢方式

    mysql 帶多個(gè)條件的查詢方式

    這篇文章主要介紹了mysql 帶多個(gè)條件的查詢方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 分享MySQL的自動(dòng)化安裝部署的方法

    分享MySQL的自動(dòng)化安裝部署的方法

    線上的MySQL一般都采用源碼編譯,雖然MySQL的源碼編譯挺簡單的,但是試想一下,如果你有幾百臺(tái)服務(wù)器同時(shí)要安裝MySQL,難道你還一臺(tái)臺(tái)去手動(dòng)編譯、編寫配置文件嗎?這顯然太低效了,本文討論MySQL的自動(dòng)化安裝部署。
    2014-07-07
  • SQL性能優(yōu)化方法及性能測試

    SQL性能優(yōu)化方法及性能測試

    這篇文章主要介紹了SQL性能優(yōu)化方法及性能測試,文章圍繞主題展開詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助
    2022-05-05

最新評(píng)論