oracle中去掉文字中的換行符、回車符、製表符小結
一、特殊符號ascii定義
製表符 chr(9)
換行符 chr(10)
回車符 chr(13)
製表符 chr(9)
換行符 chr(10)
回車符 chr(13)
二、巢狀使用repalce,注意每次只能提交一個符號,如先回車再換行
select REPLACE(gg, chr(10), '') from dual
要注意chr(13) | | chr(10) 此類結合使用的情況比較多,回車換行在notepad中是比較好看點的,所以要考慮此種情況
select translate(string,chr(13)||chr(10),',') from dual;
1、例子一
create table TEST_1
(
VA VARCHAR2(10),
VB NUMBER(2),
VC VARCHAR2(10),
VD NUMBER(11,2),
VE NUMBER(11,4),
VCL CLOB
);
select REPLACE(gg, chr(10), '') from dual
要注意chr(13) | | chr(10) 此類結合使用的情況比較多,回車換行在notepad中是比較好看點的,所以要考慮此種情況
select translate(string,chr(13)||chr(10),',') from dual;
1、例子一
create table TEST_1
(
VA VARCHAR2(10),
VB NUMBER(2),
VC VARCHAR2(10),
VD NUMBER(11,2),
VE NUMBER(11,4),
VCL CLOB
);
SQL> select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(10),',') from test_1;
VB VC TT TRANSLATE(VC,CHR(10),',')
--- ---------- ---------- -------------------------
0 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
1 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
2 大Ba 大Babc帶 大Ba,b,c帶
b
c帶
3 C C C
1 D D D
5 A A A
5 A A A
0 A A A
0 A A A
2、例子二
要注意chr(13) | | chr(10) 此類結合使用的情況比較多,回車換行在notepad中是比較好看點的,所以要考慮此種情況
select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(13)||chr(10),',') from test_1;
SQL> select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(13)||chr(10),',') from test_1;
VB VC TT TRANSLATE(VC,CHR(13)||CHR(10),
--- ---------- ---------- ------------------------------
0 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
1 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
2 大Ba 大Babc帶 大Babc帶
b
c帶
3 C C C
1 D D D
5 A A A
5 A A A
0 A A A
0 A A A
11 rows selected
VB VC TT TRANSLATE(VC,CHR(10),',')
--- ---------- ---------- -------------------------
0 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
1 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
2 大Ba 大Babc帶 大Ba,b,c帶
b
c帶
3 C C C
1 D D D
5 A A A
5 A A A
0 A A A
0 A A A
2、例子二
要注意chr(13) | | chr(10) 此類結合使用的情況比較多,回車換行在notepad中是比較好看點的,所以要考慮此種情況
select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(13)||chr(10),',') from test_1;
SQL> select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(13)||chr(10),',') from test_1;
VB VC TT TRANSLATE(VC,CHR(13)||CHR(10),
--- ---------- ---------- ------------------------------
0 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
1 Aaaaaaaaa Aaaaaaaaa Aaaaaaaaa
2 大Ba 大Babc帶 大Babc帶
b
c帶
3 C C C
1 D D D
5 A A A
5 A A A
0 A A A
0 A A A
11 rows selected
三、對於字元大物件的符號處理
對於clob欄位中的符號處理,先to_char然後一樣的處理
對於clob欄位中的符號處理,先to_char然後一樣的處理
SQL> select to_char(vcl),replace(to_char(vcl),chr(10),'[]') from test_1;
TO_CHAR(VCL) REPLACE(TO_CHAR(VCL),CHR(10),'
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
巢狀使用repalce,注意每次只能提交一個符號,如先回車再換行 巢狀使用repalce,注意每次只能提交一個符號,如先回車再換行[]select REPLACE(gg, chr(10), '') from dual[]sel
select REPLACE(gg, chr(10), '') from dual
select translate(string,chr(13)||chr(10),',') from dual;
TO_CHAR(VCL) REPLACE(TO_CHAR(VCL),CHR(10),'
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
巢狀使用repalce,注意每次只能提交一個符號,如先回車再換行 巢狀使用repalce,注意每次只能提交一個符號,如先回車再換行[]select REPLACE(gg, chr(10), '') from dual[]sel
select REPLACE(gg, chr(10), '') from dual
select translate(string,chr(13)||chr(10),',') from dual;
func:
2.2.1 單記錄字元函式
函 數 說 明
ASCII 返回對應字元的十進位制值
CHR 給出十進位制返回字元
CONCAT 拼接兩個字串,與 || 相同
INITCAT 將字串的第一個字母變為大寫
INSTR 找出某個字串的位置
INSTRB 找出某個字串的位置和位元組數
LENGTH 以字元給出字串的長度
LENGTHB 以位元組給出字串的長度
LOWER 將字串轉換成小寫
LPAD 使用指定的字元在字元的左邊填充
LTRIM 在左邊裁剪掉指定的字元
RPAD 使用指定的字元在字元的右邊填充
RTRIM 在右邊裁剪掉指定的字元
REPLACE 執行字串搜尋和替換
SUBSTR 取字串的子串
SUBSTRB 取字串的子串(以位元組)
SOUNDEX 返回一個同音字串
TRANSLATE 執行字串搜尋和替換
TRIM 裁剪掉前面或後面的字串
UPPER 將字串變為大寫
NVL 以一個值來替換空值
ASCII 返回對應字元的十進位制值
CHR 給出十進位制返回字元
CONCAT 拼接兩個字串,與 || 相同
INITCAT 將字串的第一個字母變為大寫
INSTR 找出某個字串的位置
INSTRB 找出某個字串的位置和位元組數
LENGTH 以字元給出字串的長度
LENGTHB 以位元組給出字串的長度
LOWER 將字串轉換成小寫
LPAD 使用指定的字元在字元的左邊填充
LTRIM 在左邊裁剪掉指定的字元
RPAD 使用指定的字元在字元的右邊填充
RTRIM 在右邊裁剪掉指定的字元
REPLACE 執行字串搜尋和替換
SUBSTR 取字串的子串
SUBSTRB 取字串的子串(以位元組)
SOUNDEX 返回一個同音字串
TRANSLATE 執行字串搜尋和替換
TRIM 裁剪掉前面或後面的字串
UPPER 將字串變為大寫
NVL 以一個值來替換空值
ASCII()
是字串。返回與指定的字元對應的十進位制數。
SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
A a ZERO SPACE
---------- ---------- ---------- ----------
65 97 48 32
---------- ---------- ---------- ----------
65 97 48 32
SQL> select ascii('趙') zhao,length('趙') leng from dual;
ZHAO LENG
---------- ----------
54740 1
---------- ----------
54740 1
CHR([NCHAR])
給出整數,返回對應字元。如:
給出整數,返回對應字元。如:
SQL> select chr(54740) zhao,chr(65) chr65 from dual;
ZH C
-- -
趙 A
-- -
趙 A
CONCAT(,)
SQL> select concat('010-','8801 8159')||'轉23' 趙元傑電話 from dual;
SQL> select concat('010-','8801 8159')||'轉23' 趙元傑電話 from dual;
趙元傑電話
-----------------
010-8801 8159 轉23
INITCAP()
返回字串c1 並第一個字母變為大寫。例如:
SQL> select initcap('simth') upp from dual;
UPP
-----
Simth
-----
Simth
INSTR(,[,[,] ] )
在一個字串中搜尋指定的字元,返回發現指定的字元的位置。
C1: 被搜尋的字串
C2: 希望搜尋的字串
I: 搜尋的開始位置,預設是1
J: 出現的位置,預設是1。
在一個字串中搜尋指定的字元,返回發現指定的字元的位置。
C1: 被搜尋的字串
C2: 希望搜尋的字串
I: 搜尋的開始位置,預設是1
J: 出現的位置,預設是1。
SQL> SELECT INSTR ('Oracle Training', 'ra', 1, 2) "Instring" FROM DUAL;
Instring
----------
9
INSTRB(,[,[,] ] )
除了返回的位元組外 ,與INSTR 相同,
LENGTH( )
返回字串 c 的長度。
SQL> l
1 select name,length(name),addr,length(addr),sal,length(to_char(sal))
2* from nchar_tst
SQL> /
1 select name,length(name),addr,length(addr),sal,length(to_char(sal))
2* from nchar_tst
SQL> /
NAME LENGTH(NAME) ADDR LENGTH(ADDR) SAL LENGTH(TO_CHAR(SAL))
------ ------------ ---------------- ------------ ---------- ----------------
趙元傑 3 北京市海淀區 6 99999.99 8
LENGTHB( )
以位元組返回字串的位元組數。
SQL> select name,lengthb(name),length(name) from nchar_tst;
NAME LENGTHB(NAME) LENGTH(NAME)
------ ------------- ------------
趙元傑 6 3
LOWER ( )
返回字串並將所有字元變為小寫。
返回字串並將所有字元變為小寫。
SQL> select lower('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
aabbccdd
UPPER( )
與 LOWER 相反,將給出字串變為大寫。如:
與 LOWER 相反,將給出字串變為大寫。如:
SQL> select upper('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
AABBCCDD
RPAD 和LPAD(貼上字元)
RPAD(string,Length[,'set'])
LPAD(string,Length[,'set'])
RPAD在列的右邊貼上字元;
LPAD在列的左邊貼上字元。
例 1:
SQL>select RPAD(City,35,'.'),temperature from weather;
RPAD(City,35,'.') temperature
-------------------------- ----------------
CLEVELAND...... 85
LOS ANGELES.. 81
.........................
(即不夠 35 個字元用'.'填滿)
RPAD 和LPAD(貼上字元)
RPAD(string,Length[,'set'])
LPAD(string,Length[,'set'])
RPAD在列的右邊貼上字元;
LPAD在列的左邊貼上字元。
例 1:
SQL>select RPAD(City,35,'.'),temperature from weather;
RPAD(City,35,'.') temperature
-------------------------- ----------------
CLEVELAND...... 85
LOS ANGELES.. 81
.........................
(即不夠 35 個字元用'.'填滿)
LTRIM(左截斷)RTRIM(右截斷) 函式
LTRIM (string [,’set’])
Left TRIM (左截斷)刪去左邊出現的任何set 字元。
RTRIM (string [,’set’])
Right TRIM (右截斷)刪去右邊出現的任何set 字元。
例1:
SELECT RTRIM (‘Mother Theresa, The’, ‘The’) “Example of Right
Trimming” FROM DUAL;
Example of Right
----------------
Mother Theresa,
SUBSTR Substr(string,start[,Count])
取子字串中函式
對字串 (或欄位),從 start字元 開始,連續取 count 個字元並返回結果,如果沒有指 count
則一直取到尾。
select phone,substr(phone,1,3) || ‘0’ || substr(phone,4)
from telecommunication where master ’中國電信’;
對字串 (或欄位),從 start字元 開始,連續取 count 個字元並返回結果,如果沒有指 count
則一直取到尾。
select phone,substr(phone,1,3) || ‘0’ || substr(phone,4)
from telecommunication where master ’中國電信’;
SUBSTRB(string,start[,Count])
對字串 (或欄位),從 start位元組 開始,連續取 count 個位元組並返回結果,如果沒有指 count
則一直取到尾。
REPLACE (‘string’ [,’string_in’,’string_out’])
對字串 (或欄位),從 start位元組 開始,連續取 count 個位元組並返回結果,如果沒有指 count
則一直取到尾。
REPLACE (‘string’ [,’string_in’,’string_out’])
String: 希望被替換的字串或變數。
String_in: 被替換字串。
String_out: 要替換字串。
SQL> select replace('Informaix 中國公司','Informaix','IBM Informix')
2 IBM 資料庫 from dual;
String_in: 被替換字串。
String_out: 要替換字串。
SQL> select replace('Informaix 中國公司','Informaix','IBM Informix')
2 IBM 資料庫 from dual;
IBM 資料庫
--------------------
IBM Informix 中國公司
--------------------
IBM Informix 中國公司
SOUNDEX( )
返回一個與給定的字串讀音相同的字串(不管拼寫是否一樣)。
SELECT DPL_NAME FROM DENIED_PARTIES_LIST WHERE
SOUNDEX(DPL_NAME) = SOUNDEX(‘Saddam Hussain’) ;
DPL_NAME
----------------------------------------------
Al Husseni
Sadda Al Sada.
SOUNDEX(DPL_NAME) = SOUNDEX(‘Saddam Hussain’) ;
DPL_NAME
----------------------------------------------
Al Husseni
Sadda Al Sada.
REPLACE (‘string’ [,’string_in’,’string_out’])
String:希望被替換的字串或變數。
String_in: 被替換字串。
String_out: 要替換字串。
SELECT REPLACE (‘Oracle’, ‘Or’, ‘Mir’) “Example “ FROM DUAL;
Example
-------
Miracle
String_in: 被替換字串。
String_out: 要替換字串。
SELECT REPLACE (‘Oracle’, ‘Or’, ‘Mir’) “Example “ FROM DUAL;
Example
-------
Miracle
TRIM ( [] FROM )
RIM可以使你對給定的字串進行裁剪(前面,後面或前後)。
RIM可以使你對給定的字串進行裁剪(前面,後面或前後)。
z 如果指定 LEADING, Oracle 從trim_char 中裁剪掉前面的字元;
z 如果指定TRAILING, Oracle 從trim_char 中裁剪掉尾面的字元;
z 如果指定兩個都指定或一個都沒有給出,Oracle從trim_char 中裁剪掉前面及尾面的字
符;
z 如果不指定 trim_character, 預設為空格符;
z 如果只指定trim_source, Oracle Oracle從trim_char 中裁剪掉前面及尾面的字元。
例子:將下面字串中的前面和後面的‘0 ‘字元都去掉:
z 如果指定TRAILING, Oracle 從trim_char 中裁剪掉尾面的字元;
z 如果指定兩個都指定或一個都沒有給出,Oracle從trim_char 中裁剪掉前面及尾面的字
符;
z 如果不指定 trim_character, 預設為空格符;
z 如果只指定trim_source, Oracle Oracle從trim_char 中裁剪掉前面及尾面的字元。
例子:將下面字串中的前面和後面的‘0 ‘字元都去掉:
SELECT TRIM (0 FROM 0009872348900) "TRIM Example" FROM DUAL;
TRIM example
--------------------------------
98723489
語法:TRANSLATE(expr,from,to)
om,to) expr: 代表一串字元,
expr: 代表一串字元,from 與 to 是從左到右一一對應的關係,如果不能對應,則視為空值。
舉例:
select translate('abcbbaadef','ba','#@') from dual (b將被#替代,a將被@替代)
select translate(ab
select translate('abcbbaadef','bad','#@') from dual (b將被#替代,a將被@替代,d對應的值是空值,將被移走)
因此:結果依次為:@#c##@@def 和@#c##@@ef
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/543979/viewspace-691752/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle中去掉文字中的換行符、回車符、製表符Oracle
- 批次去掉Word/WPS中的回車符符號符號
- oracle 回車、換行符Oracle
- CHARINDEX、表中有製表符、換行符、回車符的查詢和取消掉的方法Index
- 替換SQL欄位中的換行符,回車符,空格等特殊符號SQL符號
- sqlserver查詢一張表所有欄位是否含製表符、換行符、回車符SQLServer
- 怎樣讓word不顯示回車符號 如何去掉word中的回車符符號
- oracle去掉資料裡的tab、回車、換行等特殊符號Oracle符號
- 【換行符】Windows、Unix、Mac不同作業系統的回車符 和換行符 WindowsMac作業系統
- ultraedit中將某字元替換為回車符字元
- js將文字框的內容回車換行符轉換為<br/>換行JS
- 去掉linux文字檔案中的 ^M 符號Linux符號
- **PHP中替換換行符PHP
- Linux - 回車符和換行符及其在不同系統上的區別Linux
- 正規表示式.號元字元(除了回車符\r和換行符\n)字元
- linux下的製表符和換行Linux
- SQLServer中Tab製表符的影響SQLServer
- Java經典例項:在文字中匹配換行符Java
- excel表裡分隔符替換為製表符的操作方法Excel
- sqlserver資料庫 去除欄位中空格,換行符,回車符(使用replace語句)SQLServer資料庫
- gvim中換行符(Enter鍵)的操作
- sed 取消檔案中的換行符
- 用查詢替換快速批次刪除Word中的回車符號符號
- shell去掉echo和cat 的行前空格或製表符
- SQL —— 時刻提防一些髒資料 [ 回車, 換行, 空格, Tab鍵形成的製表符 ]SQL
- 回車符號 ‘ ’ 的實際應用符號
- 換行符處理
- Git中的AutoCRLF與SafeCRLF換行符問題Git
- javascript中!=、!==、==、===操作符總結JavaScript
- python按行讀取檔案,如何去掉換行符"\n"Python
- 菜鳥教程之工具使用(八)——EGit禁止自動轉換回車換行符Git
- python實現readline去掉換行符nPython
- linux 中 grep匹配 區分空格和製表符Linux
- c#換行符及空格符(轉義字元)C#字元
- Linux 轉換換行符Linux
- 微信小程式實現轉義換行符微信小程式
- vim介面去掉^M符號符號
- python3迴圈中如何加入換行符?Python