首先便是這Trim函數(shù)。Trim 函數(shù)具有刪除任意指定字符的功能,而去除字符串首尾空格則是trim函數(shù)被使用頻率最高的一種。語法Trim ( string ) ,參數(shù)string:string類型,指定要刪除首部和尾部空格的字符串返回值String。函數(shù)執(zhí)行成功時返回刪除了string字符串首部和尾部空格的字符串,發(fā)生錯誤時返回空字符串("")。 如果參數(shù)值為null時,會拋出空指針異常。在oracle中,trim使用的形式多為人rtrim()與ltrim()兩種,分別為去除字符串右邊空格與去除字符串左邊空格。
創(chuàng)新互聯(lián)專注于惠山企業(yè)網(wǎng)站建設,成都響應式網(wǎng)站建設,電子商務商城網(wǎng)站建設。惠山網(wǎng)站建設公司,為惠山等地區(qū)提供建站服務。全流程按需求定制網(wǎng)站,專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務
當然trim的功能不止如此,下面進行細致的介紹,這里我多以去除字符串空格為例。
我們看下trim函數(shù)的語法描述:trim( [ { {leading|trailing|both} [trim_character]|trim_character} from] trim_source
1)、不使用任何參數(shù)
SQL select trim(' 11 ') aa from dual;
AA
--
11
這是最常見的一種使用方法,都使用默認的參數(shù),默認情況下TRIM會同時刪除字符串前后出現(xiàn)的空格。
2)、使用both參數(shù),效果等同于方法一不使用任何參數(shù)
SQL select trim(both from ' 11 ') aa from dual;
AA
--
11
“BOTH”參數(shù)表示同時去除字符串前后所指定的內(nèi)容(默認情況下刪除空格)。
3)、使用leading與trailing參數(shù)
SQL select trim(leading from ' 11 ') aa from dual;
AA
----
11
SQL select trim(trailing from ' 11 ') aa from dual;
AA
-----
11
從結(jié)果中得分隔符'-',可以發(fā)現(xiàn)使用leading參數(shù)可以去除字符串右端的空格,而trailing參數(shù)則可以去除字符串左端的空格。正如oracle提供的rtrim()與ltrim()。
4)、使用trim_character參數(shù)
trim_character參數(shù)改變了“刪除空格”的默認行為。如果想要刪除字符串'xxxxWORLDxxxx'前后出現(xiàn)的“x”,“trim_character”參數(shù)就派上用場了。
SQL select trim('x' from 'xxxxWORLDxxxx') aaaaa from dual;
AAAAA
-----
WORLD
trim_character配合“both”、“trailing”和“l(fā)eading”三個參數(shù)使用效果如下,與之前演示類似。看結(jié)果,不贅述。
SQL select trim('x' from 'xxxxWORLDxxxx') aaaaa from dual;
AAAAA
-----
WORLD
SQL select trim(both 'x' from 'xxxxWORLDxxxx') aaaaa from dual;
AAAAA
-----
WORLD
SQL select trim(trailing 'x' from 'xxxxWORLDxxxx') aaaaa from dual;
AAAAA
---------
xxxxWORLD
SQL select trim(leading 'x' from 'xxxxWORLDxxxx') aaaaa from dual;
AAAAA
---------
WORLDxxxx
必須注意的一點是這里的“trim_character”參數(shù)只允許包含一個字符,不支持多字符。trim不能滿足我們?nèi)コ嘧址?,但是我們可以使用rtrim和ltrim來處理。
1)使用rtrim
SQL select rtrim('ORxxxxWORLDxxxxOR','OR') aaaaa from dual;
AAAAA
---------------
ORxxxxWORLDxxxx
2)使用ltrim
SQL select ltrim('ORxxxxWORLDxxxxOR','OR') aaaaa from dual;
AAAAA
---------------
xxxxWORLDxxxxOR
3)聯(lián)合使用RTRIM和LTRIM函數(shù)達到我們的目的
SQL select rtrim(ltrim('ORxxxxWORLDxxxxOR','OR'),'OR') aaaaa from dual;
AAAAA
-------------
xxxxWORLDxxxx
使用rtrim和ltrim函數(shù)時的注意事項:“OR”不表示整個“OR”字符串進行匹配,而是發(fā)現(xiàn)任意的字符“O”或字符“R”均做刪除操作。
對于trim函數(shù)的應用就介紹到,下面介紹一下replace函數(shù),個人覺得replace函數(shù)在去空格時更好用。replace 函數(shù)用第三個表達式替換第一個字符串表達式中出現(xiàn)的所有第二個給定字符串表達式。來看下replace函數(shù)的語法描述:replace('string_replace1','string_replace2','string_replace3')
'string_replace1' 待搜索的字符串表達式,string_replace1 可以是字符數(shù)據(jù)或二進制數(shù)據(jù)。
'string_replace2' 待查找的字符串表達式,string_replace2 可以是字符數(shù)據(jù)或二進制數(shù)據(jù)。
'string_replace3' 替換用的字符串表達式,string_replace3 可以是字符數(shù)據(jù)或二進制數(shù)據(jù)。
返回類型,如果 string_replace(1、2 或 3)是支持的字符數(shù)據(jù)類型之一,則返回字符數(shù)據(jù);如果 string_replace(1、2 或 3)是支持的 binary 數(shù)據(jù)類型之一,則返回二進制數(shù)據(jù)。
這里我們依然以去空格為例。
SQL select replace(' aa kk ',' ','') abcd from dual;
ABCD
----
aakk
與使用trim函數(shù)的結(jié)果進行對比,我們可以發(fā)現(xiàn),使用replace函數(shù)不僅可以去除字符串兩端的空格,也可去除字符串內(nèi)部的空格。
當然,如果只是要去除字符串兩端的空格,使用trim函數(shù)效率會更高。
replace(a.xxxx,' ','');把空格替換為空
一般空格就是一個空,\t這種空格我沒見過不知道你說的是哪種,一般特殊字符不是用\表示的,比如換行符的表示方法是chr(13)
一般的話使用nvl函數(shù)處理就可以。
格式:NVL( string1, replace_with)
功能:
如果string1為NULL,則NVL函數(shù)返回replace_with的值,否則返回原來的值。
在查詢語句中用rtrim()去調(diào)右邊的空格,或者在程序中處理,一般可以在程序中處理。
update table set name=replace(name," ","");select replace(name," ","") from table;
兩種方式均可,第一種將數(shù)據(jù)庫中數(shù)據(jù)改變,第二種不改變數(shù)據(jù)庫中的數(shù)據(jù),直接查詢。需要用到replace()函數(shù)。含義為:替換字符串;replace(原字段,“原字段舊內(nèi)容“,“原字段新內(nèi)容“)。
擴展資料:
oracle常用字符串函數(shù)
1、CHR
語法: chr(x)
功能:返回在數(shù)據(jù)庫字符集中與X擁有等價數(shù)值的字符。CHR和ASCII是一對反函數(shù)。經(jīng)過CHR轉(zhuǎn)換后的字符再經(jīng)過ASCII轉(zhuǎn)換又得到了原來的字符。
使用位置:過程性語句和SQL語句。
2、CONCAT
語法:?CONCAT(string1,string2)
功能:返回string1,并且在后面連接string2。
使用位置:過程性語句和SQL語句。
3、INITCAP
語法:INITCAP(string)
功能:返回字符串的每個單詞的第一個字母大寫而單詞中的其他字母小寫的string。單詞是用.空格或給字母數(shù)字字符進行分隔。不是字母的字符不變動。
使用位置:過程性語句和SQL語句。
4、LTRIM
語法:LTRIM(string1,string2)
功能:返回刪除從左邊算起出現(xiàn)在string2中的字符的string1。String2被缺省設置為單個的空格。數(shù)據(jù)庫將掃描string1,從最左邊開始。當遇到不在string2中的第一個字符,結(jié)果就被返回了。LTRIM的行為方式與RTRIM很相似。
使用位置:過程性語句和SQL語句。
5、NLS_INITCAP
語法:NLS_INITCAP(string[,nlsparams])
功能:返回字符串每個單詞第一個字母大寫而單詞中的其他字母小寫的string,nlsparams
指定了不同于該會話缺省值的不同排序序列。如果不指定參數(shù),則功能和INITCAP相同。Nlsparams可以使用的形式是:
byte bytes[] = {(byte)0xC2,(byte)0xA0};
String UTFSpace =null;
try {
UTFSpace =new String(bytes,"utf-8");
}catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
contentDto.put("bigTitle",detailNewsDto.getBigTitle().replaceAll(UTFSpace, " "));
喜歡請關(guān)注“蛋皮皮”微信公眾號