一、字符串查找函數(shù)? INSTR()
創(chuàng)新互聯(lián)建站長期為上千多家客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為房縣企業(yè)提供專業(yè)的網(wǎng)站制作、成都網(wǎng)站建設(shè),房縣網(wǎng)站改版等技術(shù)服務(wù)。擁有十多年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
二、字符串截取函數(shù) SUBSTR()
三、實際應(yīng)用: SUBSTR 和 INSTR 結(jié)合使用
例:(1) INSTR('todayisabeautifulday' , 'to')??
返回結(jié)果:1 (因為字符串索引號從1開始,所以返回1,不是返回0)
(2)? INSTR('todayisabeautifulday' , 'day',1, 1)
返回結(jié)果: 3 (返回第一次查出 day 的位置)
(3) 若改成 INSTR('todayisabeautifulday' , 'day',1, 2)
則返回結(jié)果為第二次出現(xiàn) day 的位置:18
(4) INSTR('today is a beautiful day' , 'is',1, 1)
返回結(jié)果:7 (空格也是一個字符)
例:(1)SUBSTR ('ABCDEFG', 2, 3)
返回結(jié)果:'BCD' (從第2個字符開始,截取長度為3的子串)
(2)substr('ABCDEFG',? -2)?
返回結(jié)果:'FG'?? (從倒數(shù)第2個字符開始,截取到源串的末尾)
(3)substr('ABCDEFG', -4, 2)
返回結(jié)果:'DE' (從倒數(shù)第4個字符開始,截取長度為2的子串)
(4)substr('ABCDEFG', 4, -1)
返回結(jié)果: 空字符串 (截取長度小于1時,返回空字符串?)
結(jié)合 SUBSTR()和 INSTR()來實現(xiàn)截取字符串中特定字符前后的字符串
(1)截取 “hello,world” 字符串中 “,” 分隔符之前的字符串
(2)截取 “hello,world, ye” 字符串中第1次出現(xiàn)的 “,” 字符和第2次出現(xiàn)的 “,” 字符之間的字符串
參考鏈接:
substr Oracle中的截取字符串函數(shù)。
字符串值:start_position,截取字符串的初始位置, Number型,start_position為負(fù)數(shù)時,表示從字符串右邊數(shù)起。length截取位數(shù),Number型,其中,length為可選,如果length為空,則返回start_position后面的所有字符。從start_position開始,取出length個字符并返回取出的字符串。
輸出結(jié)果
The original string str1 is:
Heterological paradoxes are persistent.
The substring str1 copied is: logical
The default substring str3 is:
Heterological paradoxes are persistent.
which is the entire original string.
}
substr(字符串,-10)
Oracle 字符串函數(shù) substr(字符串,截取開始位置,截取長度)
1. 如果最后一個截取長度參數(shù)為空,則表示從截取開始位置起截到最末
2. 如果截取開始位置 為大于0的數(shù)字,則表示從字符串左數(shù)幾位開始
3. 如果截取開始位置 為小于0的數(shù)字,則表示從字符串右數(shù)幾位開始
如果Oracle版本不是太低的話,使用 正則表達式函數(shù) REGEXP_SUBSTR 處理。\x0d\x0a\x0d\x0a5個參數(shù)\x0d\x0a第一個是輸入的字符串\x0d\x0a第二個是正則表達式\x0d\x0a第三個是標(biāo)識從第幾個字符開始正則表達式匹配。(默認(rèn)為1)\x0d\x0a第四個是標(biāo)識第幾個匹配組。(默認(rèn)為1)\x0d\x0a第五個是是取值范圍:\x0d\x0ai:大小寫不敏感;\x0d\x0ac:大小寫敏感;\x0d\x0an:點號 . 不匹配換行符號;\x0d\x0am:多行模式;\x0d\x0ax:擴展模式,忽略正則表達式中的空白字符。\x0d\x0a\x0d\x0aSQL SELECT\x0d\x0a 2 REGEXP_SUBSTR(a,'[0-9]+')\x0d\x0a 3 FROM\x0d\x0a 4 test_reg_substr\x0d\x0a 5 WHERE\x0d\x0a 6 REGEXP_LIKE(a, '[0-9]+');
oracle中,截取某個字符串前的字符需要用instr函數(shù)和substr函數(shù)共同完成。
工具:oracle 10g
步驟:
1、以截取字符串“210-1106000001”中“-”前的部分為例。
2、執(zhí)行語句為:
select?substr('210-1106000001',1,instr('210-1106000001','-')-1)?from?dual;
3、結(jié)果為:
instr函數(shù)語法:instr( string1, string2, start_position,nth_appearance )
參數(shù)含義:
substr函數(shù)語法:substr(strings|express,m,[n])
參數(shù)含義:
strings|express :被截取的字符串或字符串表達式。
m 從第m個字符開始截取。
n 截取后字符串長度為n。