ascii碼中換行符 chr(10),回車符 chr(13),所以用replace函數(shù)替換成空值即可。
創(chuàng)新互聯(lián)建站專注于富源企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站,商城網(wǎng)站建設(shè)。富源網(wǎng)站建設(shè)公司,為富源等地區(qū)提供建站服務(wù)。全流程按需搭建網(wǎng)站,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
select?replace(replace(字段,chr(10),''),chr(13),'')?from?表名
oracle中去掉文本中的換行符、回車符、制表符小結(jié)
一、特殊符號(hào)ascii定義
制表符 chr(9)
換行符 chr(10)
回車符 chr(13)
二、嵌套使用repalce,注意每次只能提交一個(gè)符號(hào),如先回車再換行
select REPLACE(gg, chr(10), '') from dual
要注意chr(13) | | chr(10) 此類結(jié)合使用的情況比較多,回車換行在notepad中是比較好看點(diǎn)的,所以要考慮此種情況
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) 此類結(jié)合使用的情況比較多,回車換行在notepad中是比較好看點(diǎn)的,所以要考慮此種情況
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
三、對(duì)于字符大對(duì)象的符號(hào)處理
對(duì)于clob字段中的符號(hào)處理,先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,注意每次只能提交一個(gè)符號(hào),如先回車再換行 嵌套使用repalce,注意每次只能提交一個(gè)符號(hào),如先回車再換行[]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 單記錄字符函數(shù)
函 數(shù) 說(shuō) 明
ASCII 返回對(duì)應(yīng)字符的十進(jìn)制值
CHR 給出十進(jìn)制返回字符
CONCAT 拼接兩個(gè)字符串,與 || 相同
INITCAT 將字符串的第一個(gè)字母變?yōu)榇髮?/p>
INSTR 找出某個(gè)字符串的位置
INSTRB 找出某個(gè)字符串的位置和字節(jié)數(shù)
LENGTH 以字符給出字符串的長(zhǎng)度
LENGTHB 以字節(jié)給出字符串的長(zhǎng)度
LOWER 將字符串轉(zhuǎn)換成小寫
LPAD 使用指定的字符在字符的左邊填充
LTRIM 在左邊裁剪掉指定的字符
RPAD 使用指定的字符在字符的右邊填充
RTRIM 在右邊裁剪掉指定的字符
REPLACE 執(zhí)行字符串搜索和替換
SUBSTR 取字符串的子串
SUBSTRB 取字符串的子串(以字節(jié))
SOUNDEX 返回一個(gè)同音字符串
TRANSLATE 執(zhí)行字符串搜索和替換
TRIM 裁剪掉前面或后面的字符串
UPPER 將字符串變?yōu)榇髮?/p>
NVL 以一個(gè)值來(lái)替換空值
ASCII(c1)
c1是字符串。返回與指定的字符對(duì)應(yīng)的十進(jìn)制數(shù)。
SQL select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
A a ZERO SPACE
---------- ---------- ---------- ----------
65 97 48 32
SQL select ascii('趙') zhao,length('趙') leng from dual;
ZHAO LENG
---------- ----------
54740 1
CHR(I[NCHAR])
給出整數(shù),返回對(duì)應(yīng)字符。如:
SQL select chr(54740) zhao,chr(65) chr65 from dual;
ZH C
-- -
趙 A
CONCAT(c1,c2)
SQL select concat('010-','8801 8159')||'轉(zhuǎn)23' 趙元杰電話 from dual;
趙元杰電話
-----------------
010-8801 8159 轉(zhuǎn)23
INITCAP(c1)
返回字符串c1 并第一個(gè)字母變?yōu)榇髮?。例如?/p>
SQL select initcap('simth') upp from dual;
UPP
-----
Simth
INSTR(c1,c2[,I[,j] ] )
在一個(gè)字符串中搜索指定的字符,返回發(fā)現(xiàn)指定的字符的位置。
C1: 被搜索的字符串
C2: 希望搜索的字符串
I: 搜索的開(kāi)始位置,缺省是1
J: 出現(xiàn)的位置,缺省是1。
SQL SELECT INSTR ('Oracle Training', 'ra', 1, 2) "Instring" FROM DUAL;
Instring
----------
9
INSTRB(c1,c2[,I[,j] ] )
除了返回的字節(jié)外 ,與INSTR 相同,
LENGTH( c )
返回字符串 c 的長(zhǎng)度。
SQL l
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 北京市海淀區(qū) 6 99999.99 8
LENGTHB( c )
以字節(jié)返回字符串的字節(jié)數(shù)。
SQL select name,lengthb(name),length(name) from nchar_tst;
NAME LENGTHB(NAME) LENGTH(NAME)
------ ------------- ------------
趙元杰 6 3
LOWER ( c )
返回字符串并將所有字符變?yōu)樾憽?/p>
SQL select lower('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
aabbccdd
UPPER( c)
與 LOWER 相反,將給出字符串變?yōu)榇髮憽H纾?/p>
SQL select upper('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
AABBCCDD
RPAD 和LPAD(粘貼字符)
RPAD(string,Length[,'set'])
LPAD(string,Length[,'set'])
RPAD在列的右邊粘貼字符;
LPAD在列的左邊粘貼字符。
例 1:
SQLselect RPAD(City,35,'.'),temperature from weather;
RPAD(City,35,'.') temperature
-------------------------- ----------------
CLEVELAND...... 85
LOS ANGELES.. 81
.........................
(即不夠 35 個(gè)字符用'.'填滿)
LTRIM(左截?cái)?RTRIM(右截?cái)啵?函數(shù)
LTRIM (string [,’set’])
Left TRIM (左截?cái)?刪去左邊出現(xiàn)的任何set 字符。
RTRIM (string [,’set’])
Right TRIM (右截?cái)?刪去右邊出現(xiàn)的任何set 字符。
例1:
SELECT RTRIM (‘Mother Theresa, The’, ‘The’) “Example of Right
Trimming” FROM DUAL;
Example of Right
----------------
Mother Theresa,
SUBSTR Substr(string,start[,Count])
取子字符串中函數(shù)
對(duì)字串 (或字段),從 start字符 開(kāi)始,連續(xù)取 count 個(gè)字符并返回結(jié)果,如果沒(méi)有指 count
則一直取到尾。
select phone,substr(phone,1,3) || ‘0’ || substr(phone,4)
from telecommunication where master ’中國(guó)電信’;
SUBSTRB(string,start[,Count])
對(duì)字串 (或字段),從 start字節(jié) 開(kāi)始,連續(xù)取 count 個(gè)字節(jié)并返回結(jié)果,如果沒(méi)有指 count
則一直取到尾。
REPLACE (‘string’ [,’string_in’,’string_out’])
String: 希望被替換的字符串或變量。
String_in: 被替換字符串。
String_out: 要替換字符串。
SQL select replace('Informaix 中國(guó)公司','Informaix','IBM Informix')
2 IBM 數(shù)據(jù)庫(kù) from dual;
IBM 數(shù)據(jù)庫(kù)
--------------------
IBM Informix 中國(guó)公司
SOUNDEX( c )
返回一個(gè)與給定的字符串讀音相同的字符串(不管拼寫是否一樣)。
SELECT DPL_NAME FROM DENIED_PARTIES_LIST WHERE
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
TRIM ( [leading] trailing FROM trim_char )
RIM可以使你對(duì)給定的字符串進(jìn)行裁剪(前面,后面或前后)。
z 如果指定 LEADING, Oracle 從trim_char 中裁剪掉前面的字符;
z 如果指定TRAILING, Oracle 從trim_char 中裁剪掉尾面的字符;
z 如果指定兩個(gè)都指定或一個(gè)都沒(méi)有給出,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
語(yǔ)法:TRANSLATE(expr,from,to)
om,to) expr: 代表一串字符,
expr: 代表一串字符,from 與 to 是從左到右一一對(duì)應(yīng)的關(guān)系,如果不能對(duì)應(yīng),則視為空值。
舉例:
select translate('abcbbaadef','ba','#@') from dual?。╞將被#替代,a將被@替代)
select translate(ab
select translate('abcbbaadef','bad','#@') from dual (b將被#替代,a將被@替代,d對(duì)應(yīng)的值是空值,將被移走)
因此:結(jié)果依次為:@#c##@@def 和@#c##@@ef
oracle中去掉文本中的換行符、回車符、制表符小結(jié)
一、特殊符號(hào)ascii定義
制表符 chr(9)
換行符 chr(10)
回車符 chr(13)
二、嵌套使用repalce,注意每次只能提交一個(gè)符號(hào),如先回車再換行
select REPLACE(gg, chr(10), '') from dual
要注意chr(13) | | chr(10) 此類結(jié)合使用的情況比較多,回車換行在notepad中是比較好看點(diǎn)的,所以要考慮此種情況
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) 此類結(jié)合使用的情況比較多,回車換行在notepad中是比較好看點(diǎn)的,所以要考慮此種情況
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
三、對(duì)于字符大對(duì)象的符號(hào)處理
對(duì)于clob字段中的符號(hào)處理,先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,注意每次只能提交一個(gè)符號(hào),如先回車再換行 嵌套使用repalce,注意每次只能提交一個(gè)符號(hào),如先回車再換行[]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 單記錄字符函數(shù)
函 數(shù) 說(shuō) 明
ASCII 返回對(duì)應(yīng)字符的十進(jìn)制值
CHR 給出十進(jìn)制返回字符
CONCAT 拼接兩個(gè)字符串,與 || 相同
INITCAT 將字符串的第一個(gè)字母變?yōu)榇髮?/p>
INSTR 找出某個(gè)字符串的位置
INSTRB 找出某個(gè)字符串的位置和字節(jié)數(shù)
LENGTH 以字符給出字符串的長(zhǎng)度
LENGTHB 以字節(jié)給出字符串的長(zhǎng)度
LOWER 將字符串轉(zhuǎn)換成小寫
LPAD 使用指定的字符在字符的左邊填充
LTRIM 在左邊裁剪掉指定的字符
RPAD 使用指定的字符在字符的右邊填充
RTRIM 在右邊裁剪掉指定的字符
REPLACE 執(zhí)行字符串搜索和替換
SUBSTR 取字符串的子串
SUBSTRB 取字符串的子串(以字節(jié))
SOUNDEX 返回一個(gè)同音字符串
TRANSLATE 執(zhí)行字符串搜索和替換
TRIM 裁剪掉前面或后面的字符串
UPPER 將字符串變?yōu)榇髮?/p>
NVL 以一個(gè)值來(lái)替換空值
ASCII(c1)
c1是字符串。返回與指定的字符對(duì)應(yīng)的十進(jìn)制數(shù)。
SQL select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
A a ZERO SPACE
---------- ---------- ---------- ----------
65 97 48 32
SQL select ascii('趙') zhao,length('趙') leng from dual;
ZHAO LENG
---------- ----------
54740 1
CHR(I[NCHAR])
給出整數(shù),返回對(duì)應(yīng)字符。如:
SQL select chr(54740) zhao,chr(65) chr65 from dual;
ZH C
-- -
趙 A
CONCAT(c1,c2)
SQL select concat('010-','8801 8159')||'轉(zhuǎn)23' 趙元杰電話 from dual;
趙元杰電話
-----------------
010-8801 8159 轉(zhuǎn)23
INITCAP(c1)
返回字符串c1 并第一個(gè)字母變?yōu)榇髮?。例如?/p>
SQL select initcap('simth') upp from dual;
UPP
-----
Simth
INSTR(c1,c2[,I[,j] ] )
在一個(gè)字符串中搜索指定的字符,返回發(fā)現(xiàn)指定的字符的位置。
C1: 被搜索的字符串
C2: 希望搜索的字符串
I: 搜索的開(kāi)始位置,缺省是1
J: 出現(xiàn)的位置,缺省是1。
SQL SELECT INSTR ('Oracle Training', 'ra', 1, 2) "Instring" FROM DUAL;
Instring
----------
9
INSTRB(c1,c2[,I[,j] ] )
除了返回的字節(jié)外 ,與INSTR 相同,
LENGTH( c )
返回字符串 c 的長(zhǎng)度。
SQL l
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 北京市海淀區(qū) 6 99999.99 8
LENGTHB( c )
以字節(jié)返回字符串的字節(jié)數(shù)。
SQL select name,lengthb(name),length(name) from nchar_tst;
NAME LENGTHB(NAME) LENGTH(NAME)
------ ------------- ------------
趙元杰 6 3
LOWER ( c )
返回字符串并將所有字符變?yōu)樾憽?/p>
SQL select lower('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
aabbccdd
UPPER( c)
與 LOWER 相反,將給出字符串變?yōu)榇髮?。如?/p>
SQL select upper('AaBbCcDd') AaBbCcDd from dual;
AABBCCDD
--------
AABBCCDD
RPAD 和LPAD(粘貼字符)
RPAD(string,Length[,'set'])
LPAD(string,Length[,'set'])
RPAD在列的右邊粘貼字符;
LPAD在列的左邊粘貼字符。
例 1:
SQLselect RPAD(City,35,'.'),temperature from weather;
RPAD(City,35,'.') temperature
-------------------------- ----------------
CLEVELAND...... 85
LOS ANGELES.. 81
.........................
(即不夠 35 個(gè)字符用'.'填滿)
LTRIM(左截?cái)?RTRIM(右截?cái)啵?函數(shù)
LTRIM (string [,’set’])
Left TRIM (左截?cái)?刪去左邊出現(xiàn)的任何set 字符。
RTRIM (string [,’set’])
Right TRIM (右截?cái)?刪去右邊出現(xiàn)的任何set 字符。
例1:
SELECT RTRIM (‘Mother Theresa, The’, ‘The’) “Example of Right
Trimming” FROM DUAL;
Example of Right
----------------
Mother Theresa,
SUBSTR Substr(string,start[,Count])
取子字符串中函數(shù)
對(duì)字串 (或字段),從 start字符 開(kāi)始,連續(xù)取 count 個(gè)字符并返回結(jié)果,如果沒(méi)有指 count
則一直取到尾。
select phone,substr(phone,1,3) || ‘0’ || substr(phone,4)
from telecommunication where master ’中國(guó)電信’;
SUBSTRB(string,start[,Count])
對(duì)字串 (或字段),從 start字節(jié) 開(kāi)始,連續(xù)取 count 個(gè)字節(jié)并返回結(jié)果,如果沒(méi)有指 count
則一直取到尾。
REPLACE (‘string’ [,’string_in’,’string_out’])
String: 希望被替換的字符串或變量。
String_in: 被替換字符串。
String_out: 要替換字符串。
SQL select replace('Informaix 中國(guó)公司','Informaix','IBM Informix')
2 IBM 數(shù)據(jù)庫(kù) from dual;
IBM 數(shù)據(jù)庫(kù)
--------------------
IBM Informix 中國(guó)公司
SOUNDEX( c )
返回一個(gè)與給定的字符串讀音相同的字符串(不管拼寫是否一樣)。
SELECT DPL_NAME FROM DENIED_PARTIES_LIST WHERE
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
TRIM ( [leading] trailing FROM trim_char )
RIM可以使你對(duì)給定的字符串進(jìn)行裁剪(前面,后面或前后)。
z 如果指定 LEADING, Oracle 從trim_char 中裁剪掉前面的字符;
z 如果指定TRAILING, Oracle 從trim_char 中裁剪掉尾面的字符;
z 如果指定兩個(gè)都指定或一個(gè)都沒(méi)有給出,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
語(yǔ)法:TRANSLATE(expr,from,to)
om,to) expr: 代表一串字符,
expr: 代表一串字符,from 與 to 是從左到右一一對(duì)應(yīng)的關(guān)系,如果不能對(duì)應(yīng),則視為空值。
舉例:
select translate('abcbbaadef','ba','#@') from dual?。╞將被#替代,a將被@替代)
select translate(ab
select translate('abcbbaadef','bad','#@') from dual?。╞將被#替代,a將被@替代,d對(duì)應(yīng)的值是空值,將被移走)
因此:結(jié)果依次為:@#c##@@def 和@#c##@@ef
如果結(jié)束符號(hào)是“;”,則輸入“c/;/”即可;
如果結(jié)束符號(hào)是“/”,則輸入“c'/'”即可。