mysql根據字符截取字符串(總結)


mysql根據字符截取字符串(總結)

1.1 前言

    為結合自己平常查資料的習慣,我會先給出例子,然后再對相關知識進行詳解。該案例使用到的函數為:SUBSTRING_INDEX

1.2 需要實現的實際需求

  1. 如下表為文檔目錄表,其中關鍵字段dir_seq為目錄層級索引,dir_name為目錄名稱。假設現在我們獲取到dir_seq值為 .341.346.347.348. ,現在我們想獲取到各級別的目錄主鍵。

1.3 截取一級目錄主鍵

  1. 步驟一:

          先根據字符'.'從左邊開始第二個'.'開始截取左邊的字符串:SUBSTRING_INDEX(dir_seq,'.',2)

           截取結果:  .341

    步驟二:

           在步驟一的截取結果再根據字符'.'從右邊開始第一個'.'開始截取右邊的字符串:SUBSTRING_INDEX( SUBSTRING_INDEX(dir_seq,'.',2) ,'.',-1)

           截取結果:  341

 

 

1.3 截取二級目錄主鍵

  1. 步驟一:
    
          先根據字符'.'從左邊開始第三個'.'開始截取左邊的字符串:SUBSTRING_INDEX(dir_seq,'.',3)
    
           截取結果:  .341.346
    
    步驟二:
    
           在步驟一的截取結果再根據字符'.'從右邊開始第一個'.'開始截取右邊的字符串:SUBSTRING_INDEX( SUBSTRING_INDEX(dir_seq,'.',3) ,'.',-1)
    
           截取結果:  346

1.4 截取三級目錄主鍵,其實從上面兩個例子已經看出規律,先從左截取三級目錄id所在的位置,再從右截取第一個'.'的位置。。。

1.5 mysql相關字符串截取的函數詳解:

  1. SUBSTRING_INDEX(subStr, matchStr, index)
    根據匹配的字符以及出現的位置開始截取字符串
    subStr: 需要截取的字段
    matchStr: 匹配的字符
    index: 從第幾個匹配的字符,為正數時從左邊開始查找並向左截取,為負數時從右邊開始查找並向右截取
  2. LEFT(subStr,index) 
    從左邊開始向右截取,截至第index位(index從1開始)
    subStr: 需要截取的字段
    index: 停止截取的位置(包括該位置的字符)
  3. RIGHT(subStr,index) 

    從右邊開始向左截取,截至從右邊開始數第index位(index從1開始)
    subStr: 需要截取的字段
    index: 停止截取的位置(包括該位置的字符)

     

  4. SUBSTRING(subStr,  index)
    index為負數時,從右邊開始向左截取,截至從右邊開始數第index
    index為正數時,從左邊開始向右截取,截至從左邊開始數第index

    subStr: 需要截取的字段
    index: 停止截取的位置(包括該位置的字符)


 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM