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

Mysql查詢去空格的多種方法匯總

 更新時間:2023年04月25日 10:52:34   作者:Conquer_El  
SQL查詢語句中空格是用來分隔關鍵字、表名、列名等的,然而空格也會影響查詢效率,因為查詢語句中的空格越多,查詢的速度就越慢,下面這篇文章主要給大家介紹了關于Mysql查詢去空格的多種方法,需要的朋友可以參考下

一、背景

        最近系統(tǒng)線上數(shù)據(jù)庫數(shù)據(jù)出現(xiàn)一個問題,發(fā)現(xiàn)某些字段存在一些異常的首尾空格,不管是使用trim對比還是like查詢都查詢不到具體的數(shù)據(jù);在網(wǎng)上找了一些方法,最后發(fā)現(xiàn)一個去“不間斷空格”的方法解決了問題,在這里做一下記錄和匯總。

二、方法

1、trim()、ltrim()、rtrim()函數(shù)

語法:trim(字段)  ||  trim([{BOTH | LEADING | TRAILING} [指定字符] FROM] 字段)

(1)trim()去除字段首尾空白字符,也可以去除指定字符

列子:去除商品零件號左右空格,以及指定字符,打印去除字符后的長度

select
	p.parts_num as "零件號(包含首尾各3個空格)",
	length(p.parts_num) as "原始長度",
	trim(p.parts_num),
	length(trim(p.parts_num)) as "去除左右空格后長度",
	trim(leading '   7' from p.parts_num),
	length(trim(leading '   7' from p.parts_num)) as "去除左邊字符后長度",
	trim(trailing '7   ' from p.parts_num),
	length(trim(trailing '7   ' from p.parts_num)) as "去除右邊字符后長度"
from
	product p
where
	p.product_id = "1941573845271945216";

結果:

(2)ltrim()去除左空格

select
	p.parts_num as "零件號(包含首尾各3個空格)",
	length(p.parts_num) as "原始長度",
	ltrim(p.parts_num),
	length(ltrim(p.parts_num)) as "去除左空格后長度"
from
	product p
where
	p.product_id = "1941573845271945216";

結果:

(3)rtrim()去除右空格

select
	p.parts_num as "零件號(包含首尾各3個空格)",
	length(p.parts_num) as "原始長度",
	rtrim(p.parts_num),
	length(rtrim(p.parts_num)) as "去除右空格后長度"
from
	product p
where
	p.product_id = "1941573845271945216";

結果:

2、replace()函數(shù)

語法:replace(object,search,replace)

(1)替換字段中指定字符為新字符

select
	p.parts_num as "零件號(包含首尾各3個空格)",
	length(p.parts_num) as "原始長度",
	replace(p.parts_num, ' ', ''),
	length(replace(p.parts_num, ' ', '')) as "替換空格后長度",
	replace(p.parts_num, '7', '8') as "把7替換成8"
from
	product p
where
	p.product_id = "1941573845271945216";

結果:

(2)指定去除一下特殊字符

水平制表符:CHAR(9)、換行符:CHAR(10)、回車符:CHAR(13)

REPLACE(REPLACE(REPLACE(p.parts_num, CHAR(9), ''), CHAR(10), ''), CHAR(13), '')

3、convert()函數(shù)配合trim()函數(shù)(解決了我的問題)

(1)使用convert()先轉換一些特殊編碼的空格(unicode碼位u+00a0的utf-8編碼,也稱為不間斷空格)轉換成常規(guī)空格(ASCII 中編碼為0x20)

-- convert轉換,trim去除
select TRIM(convert(0xC2A0 using utf8mb4) FROM p.parts_num);
 
-- 替換掉字符中的不間斷空格
select TRIM(REPLACE(p.parts_num, convert(0xC2A0 using utf8mb4), ' '));

這些特殊空格一般常見于各文本編輯器(word、Excel等,剛好出現(xiàn)問題的業(yè)務存在Excel導入數(shù)據(jù)的場景),想要詳細了解看下面推薦的文章。

補充:你不知道的空格

Level1: 半角空格

歷史最悠久的空格,在1967年,ASCII 規(guī)范中被定義。

空格在 ASCII 中編碼為0x20, 占位符為一個半角字符。在日常英文書寫和代碼編寫中使用。

Level2: 全角空格

中文輸入中的空格(標準說法為中日韓表意字符(CJK)中使用的寬空格)。和其他漢字一樣,作為GBK的一個字符,其對應的unicode碼為\u3000.寬

度是2個半角空格的大小。

例如:

  先生 孫先生 

Level3: 不間斷空格 ( non-breaking space )

unicode 為 \u00A0, 在代碼中可能會出現(xiàn)的編碼錯誤(utf8 編碼0xC2 0xA0) 就是它了。

在Word中,會遇到一個有多個單詞組成的詞組被分割在兩行文字中,這樣很容易讓人看不明白。這時候,不間斷空格就可以上場了。

輸入不間斷空格,會將不間斷空格連著的單詞在一行展示。

舉個例子:

上面英文使用了不間斷空格,下面沒有使用。所以上面的英文自動在一行展示,而下面沒有。

在word中輸入不間斷空格的方式為: (Ctrl + Shift + Space)

除了在word等文本編輯軟件中使用,其實不間斷空格在html 中大量使用。  是html 中最為常見的空格。由于html頁面中,如果有多個連著的半角空格,則空格只會展示一個。而使用  空格,則會顯示占位半個自寬。

Level4: 零寬度空格 (ZERO WIDTH SPACE)

零寬度空格有兩種

  • 零寬度空格 unicode 編碼為 \u200B.

不可見非打印字符。有了半角空格,也有了全角空格,其實還有零寬度空格。因為寬度為零,因此該字符是一個不可見字符。
這個編碼雖然是不可見的,但是也是非常有用的。它可以替換html中的標簽(軟換行, html5 新增)。

  • 零寬度非中斷空格(ZWNBSP) unicode 編碼為 \u2060 (之前使用\ufeff表示,unicode 3.2 開始 \ufeff 標記unicode文檔的字節(jié)序。)
    該空格結合了 non-breaking space 和 零寬度空格的特點。既會自動換行,寬度又是0。

零寬度空格(軟換行)舉例:

一行連續(xù)的英文編碼:

<p style="font-size:100px;">phpIsTheBestProgramingLanguageInTheWorld</p>

而如果在每個可以換行的地方加上 <wbr />, 則可以在標記的最近的地方換行。

<p style="font-size:100px;">php<wbr />Is<wbr />The<wbr />Best<wbr />Programing<wbr />Language<wbr />In<wbr />The<wbr />World</p>

Level5: 其他空格字符空格

雖然已經(jīng)有半角空格、全角空格,但是上面的空格如果字體變化了,不會隨著字體的變化而變化。

因此,又有了可以隨著字體的變化而變化的空格,簡單羅列如下:

在html 的寬度度量中,有一種單位叫em,是按照字體大小定義的,下面的em也是字體的寬度。

打印字符的空格有很多種,羅列幾個:

名稱unicode 編碼html 標記特征和用途
短空格\u2002&ensp;html 中占位半個字
長空格\u2003&emsp;html 中占位一個字
1/3em空格\u2004&emsp13;占用1/3個空格
1/4em空格\u2005&emsp14;占用1/4個空格
1/6em空格\u2006&emsp14;占用1/6個空格
數(shù)樣間距 (figure space)\u2007&numsp;在等寬字體中,寬度是一個字符的寬度。
行首前導空格 (punctuation space)\u2008&puncsp;寬度約為 0x20 的寬度。
瘦弱空格 (thin space)\u2009&thinsp;寬度是 全角打印空格的 1/5 或者 1/6 (寬度不定,法文設置為1/8), 主要用在打印兩個空的引號之間。
hair space\u200a&hairsp;(瀏覽器目前不支持), 最窄的空格,推薦標準為 (1/10, 1/16)
narrow no-break space\u202f&nnbsp;和0a 類似,不同語種中不太一樣。
medium mathematical space\u205f&mediumspace;在格式化數(shù)學公式時使用。是 4/18 的 em寬度,例如:"a + b"中,a 和+ 之間應該用 這個空格

總結 

到此這篇關于Mysql查詢去空格的文章就介紹到這了,更多相關Mysql查詢去空格內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 如何用mysql自帶的定時器定時執(zhí)行sql(每天0點執(zhí)行與間隔分/時執(zhí)行)

    如何用mysql自帶的定時器定時執(zhí)行sql(每天0點執(zhí)行與間隔分/時執(zhí)行)

    在開發(fā)過程中經(jīng)常會遇到這樣一個問題,每天或者每月必須定時去執(zhí)行一條sql語句或更新或刪除或執(zhí)行特定的sql語句,下面這篇文章主要給大家介紹了關于如何用mysql自帶的定時器定時執(zhí)行sql(每天0點執(zhí)行與間隔分/時執(zhí)行)的相關資料,需要的朋友可以參考下
    2023-03-03
  • MySQL深入詳解delete與Truncate及drop的使用區(qū)別

    MySQL深入詳解delete與Truncate及drop的使用區(qū)別

    對于drop、truncate和delete雖然簡單,但是真要使用或者面試時候問到還是需要有一定的總結,下面這篇文章主要給大家介紹了關于mysql中drop、truncate與delete區(qū)別的相關資料,需要的朋友可以參考下
    2022-07-07
  • mysql enum字段類型的謹慎使用

    mysql enum字段類型的謹慎使用

    本文主要介紹了mysql enum字段類型使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • MySQL5.7 JSON類型使用詳解

    MySQL5.7 JSON類型使用詳解

    MySQL5.7發(fā)布后,專門設計了JSON數(shù)據(jù)類型以及關于這種類型的檢索以及其他函數(shù)解析。 我們先看看MySQL老版本的JSON存取方式,具體內容詳情大家參考下本文吧
    2017-10-10
  • sql和MySQL的語句執(zhí)行順序分析

    sql和MySQL的語句執(zhí)行順序分析

    本文就sql和mysql的語句執(zhí)行順序問題向大家作了詳細介紹,小編覺得挺不錯的,這里分享下,供大家參考。
    2017-10-10
  • MySQL 5.7.30 安裝與升級問題詳細教程

    MySQL 5.7.30 安裝與升級問題詳細教程

    這篇文章主要介紹了MySQL 5.7.30 的安裝與升級教程(所有可能的坑都在這里),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • MySQL索引優(yōu)化實例分析

    MySQL索引優(yōu)化實例分析

    這篇文章主要介紹了MySQL索引優(yōu)化實例分析,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-07-07
  • 云服務器Ubuntu_Server_16.04.1安裝MySQL并開啟遠程連接的方法

    云服務器Ubuntu_Server_16.04.1安裝MySQL并開啟遠程連接的方法

    這篇文章主要介紹了云服務器Ubuntu_Server_16.04.1安裝MySQL并開啟遠程連接的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-02-02
  • MySQL慢查詢如何定位詳解

    MySQL慢查詢如何定位詳解

    這篇文章主要給大家介紹了關于MySQL慢查詢如何定位的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • MySQL 請選擇合適的列

    MySQL 請選擇合適的列

    如果你的表結構設計不良或你的索引設計不佳,那么請你優(yōu)化你的表結構設計和給予合適的索引,這樣你的查詢性能就能提高幾個數(shù)量級。——數(shù)據(jù)越大,索引的價值越能體現(xiàn)出來
    2012-05-05

最新評論