oracle sql 內建函式大全(1)
sql中的單記錄函式
1.ascii 返回與指定的字元對應的十進位制數;
sql> select ascii('a') a,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
a a zero space
--------- --------- --------- ---------
65 97 48 32
2.chr 給出整數,返回對應的字元;
sql> select chr(54740) zhao,chr(65) chr65 from dual;
zh c
-- -
趙 a
3.concat 連線兩個字串;
sql> select concat('010-','88888888')'轉23' 高乾競電話 from dual;
高乾競電話
----------------
010-88888888轉23
4.initcap 返回字串並將字串的第一個字母變為大寫;
sql> select initcap('smith') upp from dual;
upp
-----
smith
5.instr(c1,c2,i,j) 在一個字串中搜索指定的字元,返回發現指定的字元的位置;
c1 被搜尋的字串
c2 希望搜尋的字串
i 搜尋的開始位置,預設為1
j 出現的位置,預設為1
sql> select instr('
instring
---------
9
6.length 返回字串的長度;
sql> select name,length(name),addr,length(addr),sal,length(to_char(sal)) from .nchar_tst;
name length(name) addr length(addr) sal length(to_char(sal))
------ ------------ ---------------- ------------ --------- --------------------
高乾競 3 北京市海錠區 6 9999.99 7
7.lower 返回字串,並將所有的字元小寫
sql> select lower('aabbccdd')aabbccdd from dual;
aabbccdd
--------
aabbccdd
8.upper 返回字串,並將所有的字元大寫
sql> select upper('aabbccdd') upper from dual;
upper
--------
aabbccdd
9.rpad和lpad(貼上字元)
rpad 在列的右邊貼上字元
lpad 在列的左邊貼上字元
sql> select lpad(rpad('gao',10,'*'),17,'*')from dual;
lpad(rpad('gao',1
-----------------
*******gao*******
不夠字元則用*來填滿
10.ltrim和rtrim
ltrim 刪除左邊出現的字串
rtrim 刪除右邊出現的字串
sql> select ltrim(rtrim(' gao qian jing ',' '),' ') from dual;
ltrim(rtrim('
-------------
gao qian jing
11.substr(string,start,count)
取子字串,從start開始,取count個
sql> select substr('13088888888',3,8) from dual;
substr('
--------
08888888
12.replace('string','s1','s2')
string 希望被替換的字元或變數
s1 被替換的字串
s2 要替換的字串
sql> select replace('he love you','he','i') from dual;
replace('heloveyou','he','i')
------------------------------
i love you
13.soundex 返回一個與給定的字串讀音相同的字串
sql> create table table1(xm varchar(8));
sql> insert into table1 values('weather');
sql> insert into table1 values('wether');
sql> insert into table1 values('gao');
sql> select xm from table1 where soundex(xm)=soundex('weather');
xm
--------
weather
wether
14.trim('s' from 'string')
leading 剪掉前面的字元
trailing 剪掉後面的字元
如果不指定,預設為空格符
15.abs 返回指定值的絕對值
sql> select abs(100),abs(-100) from dual;
abs(100) abs(-100)
--------- ---------
100 100
16.acos 給出反餘弦的值
sql> select acos(-1) from dual;
acos(-1)
---------
3.1415927
17.asin 給出反正弦的值
sql> select asin(0.5) from dual;
asin(0.5)
---------
.52359878
18.atan 返回一個數字的反正切值
sql> select atan(1) from dual;
atan(1)
---------
.78539816
19.ceil 返回大於或等於給出數字的最小整數
sql> select ceil(3.1415927) from dual;
ceil(3.1415927)
---------------
4
20.cos 返回一個給定數字的餘弦
sql> select cos(-3.1415927) from dual;
cos(-3.1415927)
---------------
-1
21.cosh 返回一個數字反餘弦值
sql> select cosh(20) from dual;
cosh(20)
---------
242582598
22.exp 返回一個數字e的n次方根
sql> select exp(2),exp(1) from dual;
exp(2) exp(1)
--------- ---------
7.3890561 2.7182818
23.floor 對給定的數字取整數
sql> select floor(2345.67) from dual;
floor(2345.67)
--------------
2345
24.ln 返回一個數字的對數值
sql> select ln(1),ln(2),ln(2.7182818) from dual;
ln(1) ln(2) ln(2.7182818)
--------- --------- -------------
0 .69314718 .99999999
25.log(n1,n2) 返回一個以n1為底n2的對數
sql> select log(2,1),log(2,4) from dual;
log(2,1) log(2,4)
--------- ---------
0 2