sql常用函數instr()和substr()


Decode

decode(條件,值1,翻譯值1,值2,翻譯值2,...,缺省值) 該函數與程序中的 If...else if...else 意義一樣

NVL

格式:NVL( string1, replace_with)

 

功能:如果string1為NULL,則NVL函數返回replace_with的值,否則返回string1的值,如果兩個參數都為NULL ,則返回NULL。

注意事項:string1和replace_with必須為同一數據類型,除非顯式的使用TO_CHAR函數進行類型轉換。

select nvl(sum(t.dwxhl),1) from tb_jhde t 就表示如果sum(t.dwxhl) = NULL 就返回 1

Oracle在NVL函數的功能上擴展,提供了NVL2函數

NVL2

nvl2 (E1, E2, E3) 的功能為:如果E1為NULL,則函數返回E3,否則返回E2

結合

Decode 和 NVL等函數 常常結合使用,例如

select monthid,decode(nvl(sale,6000),6000,'NG','OK') from output

sign()函數根據某個值是0、正數還是負數,分別返回0、1、-1,

如果取較小值就是 select monthid,decode(sign(sale-6000),-1,sale,6000) from output,即達到取較小值的目的。

在Oracle中

可以使用instr函數對某個字符串進行判斷,判斷其是否含有指定的字符。

其語法為:
instr(sourceString,destString,start,appearPosition).   instr('源字符串' , '目標字符串' ,'開始位置','第幾次出現')
其中sourceString代表源字符串;

destString代表想聰源字符串中查找的子串;

start代表查找的開始位置,該參數可選的,默認為1;

appearPosition代表想從源字符中查找出第幾次出現的destString,該參數也是可選的,默認為1;


如果start的值為負數,那么代表從右往左進行查找,但是位置數據仍然從左向右計算。

返回值為:查找到的字符串的位置。

對於instr函數,我們經常這樣使用:從一個字符串中查找指定子串的位置。例如:
SQL> select instr('yuechaotianyuechao','ao') position from dual;

POSITION
----------
         6

從第7個字符開始搜索
SQL> select instr('yuechaotianyuechao','ao', 7) position from dual;

POSITION
----------
        17

從第1個字符開始,搜索第2次出現子串的位置
SQL> select instr('yuechaotianyuechao','ao', 1, 2) position from dual;

POSITION
----------
        17

 注意:1。若‘起始位置’=0 時返回結果為0,
           2。這里只有三個參數,意思是查找第一個要查找字符的位置(因為 ‘第幾次出現’默認為1),
當‘起始位置’不大於要查找的第一個字符的位置時,返回的值都將是第一個字符的位置,如果‘起始位置’大於要查找的第一個字符的位置時,返回的值都將是第2個字符的位置,依此類推……(但是也是以第一個字符開始計數)

 

 

substr函數的用法,取得字符串中指定起始位置和長度的字符串  ,默認是從起始位置到結束的子串。

 substr( string, start_position, [ length ] )       substr('目標字符串',開始位置,長度)
如:
     substr('This is a test', 6, 2)     would return 'is'
     substr('This is a test', 6)     would return 'is a test'
     substr('TechOnTheNet', -3, 3)     would return 'Net'
     substr('TechOnTheNet', -6, 3)     would return 'The'select substr('Thisisatest', -4, 2) value from dual 

 -------------------------------------------------------------------------------------------------

關於Instr()和substr()函數-

INSTR共有4個參數;具體格式為:
INSTR(strings|express,strings[,m,[n]])
在一個字符串中搜索指定的字符,返回發現指定的字符的位置;
strings|express 被搜索的字符串
strings 希望搜索的字符串
m 搜索的開始位置,默認為1
n 第n次出現希望搜索的字符串的位置,默認為1
1.被搜索的字符串可以為字符串,也可以為表達式
如:


QUOTE:
SQL> select instr('my 2 firefly','i') result from dual;
RESULT
----------
7
SQL> select instr(initcap('my 2 firefly')||'b','Fi') result from dual;
RESULT
----------
6


2.希望搜索的字符串可以為字符或數字字符,(希望搜索的字符串長度可以1個或多個)
如:


QUOTE:
SQL> select instr('my 2 firefly','i') result from dual;
RESULT
----------
7
SQL> select instr('my 2 firefly','iref') result from dual;
RESULT
----------
7
SQL> select instr('my 2 firefly',2) result from dual;
RESULT
----------
4
SQL> select instr('my 2 firefly',22) result from dual;
RESULT
----------
0


3.m表示要從第幾個字符開始查找
如:


QUOTE:
SQL> select instr('my 2 firefly','f',1) result from dual;
RESULT
----------
6
注意:若m=0時返回結果為0
select instr('my 2 firefly','f',0) result from dual;
RESULT
----------
0


注意:這里只有三個參數,意思是查找第一個要查找字符的位置(因為n默認為1),
當m不大於要查找的第一個字符的位置時,返回的值都將是第一個字符的位置,如果m大於要查找的第一個字符的位置時,返回的值都將是第2個字符的位置,依此類推……
如:


QUOTE:
SQL> select instr('my 2 firefly','f',1) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',3) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',6) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',7) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',10) result from dual;
RESULT
----------
10


當m大於要查找字符的最大的位置時,返回0


QUOTE:
SQL> select instr('my 2 firefly','f',11) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',110) result from dual;
RESULT
----------
0


反之亦然,若m<0,則表示從右向左來查找數據


QUOTE:
SQL> select instr('my 2 firefly','f',-1) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',-2) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',-4) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',-40) result from dual;
RESULT
----------
0


4.n表示要找第n個該字符
如:


QUOTE:
SQL> select instr('my 2 firefly','f',1,1) result from dual;
RESULT
----------
6
SQL> select instr('my 2 firefly','f',1,2) result from dual;
RESULT
----------
10
SQL> select instr('my 2 firefly','f',1,3) result from dual;
RESULT
----------
0


當n大於查找源中包含所要查找字符串的最大個數時,返回0
如:


QUOTE:
SQL> select instr('my 2 firefly','f',1,4) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',1,40) result from dual;
RESULT
----------
0


當m<0時,表示從右向左查找,如:


QUOTE:
SQL> select instr('my 2 firefly','f',-10,1) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',-8,1) result from dual;
RESULT
----------
0
SQL> select instr('my 2 firefly','f',-3,1) result from dual;
RESULT
----------
10


注意:當m不大於要查找的第一個字符的位置時,返回的值都將是第一個字符的位置,如果m大於要查找的第一個字符的位置時,返回的值都將是第2個字符的位置,依此類推……
如:


QUOTE:
SQL> select instr('my 2 firefly','f',-4,1) result from dual;
RESULT
----------
6
等同於:
SQL> select instr('my 2 firefly','f',-1,2) result from dual;
RESULT
----------
6
另注意:如果要查找的字符串為 NULL時,返回NULL
如:
SQL> select instr('my 2 firefly',null,-1,2) result from dual;
RESULT
----------
SQL> select instr('my 2 firefly',null) result from dual;
RESULT
----------
SQL> select instr('my 2 firefly',null,1) result from dual;
RESULT
----------

 


QUOTE:
================================================


字符串截取函數substr(strings|express,m,[n])
strings|express 被截取的字符串或字符串表達式
m 從第m個字符開始截取
n 截取后字符串長度為n
1.被截取的為字符串或字符串表達式


QUOTE:
SQL> select substr(upper('abcde'),1,2) from dual;
SUBSTR(UPPER('ABCDE'),1,2)
--------------------------
AB
SQL> select substr('abcde',1,2) from dual;
SUBSTR('ABCDE',1,2)
-------------------
ab


2.如果m<0,則表示從右向左截取
這里如果n>0,若n>=|m|,截取字符串長度為|m|個(從右向左截取),
若n<|m|,截取字符串長度為n個(從右向左截取)
如:


QUOTE:
SQL> select substr('abcde',-4,2) from dual;
SUBSTR('ABCDE',-4,2)
--------------------
bc
SQL> select substr('abcde',-4,1) from dual;
SUBSTR('ABCDE',-4,1)
--------------------
b
SQL> select substr('abcde',-4,4) from dual;
SUBSTR('ABCDE',-4,4)
--------------------
bcde
SQL> select substr('abcde',-4,5) from dual;
SUBSTR('ABCDE',-4,5)
--------------------
bcde
SQL> select substr('abcde',-4,50) from dual;
SUBSTR('ABCDE',-4,50)
---------------------
bcde


如果m<0,n=0結果為NULL:


QUOTE:
SQL> select substr('abcde',-4,0) from dual;
SUBSTR('ABCDE',-4,0)
--------------------
SQL> select substr('abcde',-5,0) from dual;
SUBSTR('ABCDE',-5,0)
--------------------


如果m<0,n<0結果為NULL:


QUOTE:
SQL> select substr('abcde',-2,0) from dual;
SUBSTR('ABCDE',-2,0)
--------------------
SQL> select substr('abcde',-2,-1) from dual;
SUBSTR('ABCDE',-2,-1)
---------------------
SQL> select substr('abcde',-2,-4) from dual;
SUBSTR('ABCDE',-2,-4)
---------------------
SQL> select substr('abcde',-3,-4) from dual;
SUBSTR('ABCDE',-3,-4)
---------------------


3.如果n<=0,,結果為0:


QUOTE:
SQL> select substr('abcde',1,-4) from dual;
SUBSTR('ABCDE',1,-4)
--------------------
SQL> select substr('abcde',1,-2) from dual;
SUBSTR('ABCDE',1,-2)
--------------------
SQL> select substr('abcde',1,0) from dual;
SUBSTR('ABCDE',1,0)
-------------------
SQL> select substr('abcde',1,-2) from dual;
SUBSTR('ABCDE',1,-2)
--------------------


4.m,n只要有一個為NULL,那么結果為NULL


QUOTE:
SQL> select substr('abcde',1,null) from dual;
SUBSTR('ABCDE',1,NULL)
----------------------
SQL> select substr('abcde',null,null) from dual;
SUBSTR('ABCDE',NULL,NULL)
-------------------------
SQL> select substr('abcde',null,1) from dual;
SUBSTR('ABCDE',NULL,1)
----------------------


5.不用n參數時:
n=NULL里,結果為NULL
n>=0,結果為從n個字符開始截取到最后


QUOTE:
SQL> select substr('abcde',null) from dual;
SUBSTR('ABCDE',NULL)
--------------------
SQL> select substr('abcde',0) from dual;
SUBSTR('ABCDE',0)
-----------------
abcde
SQL> select substr('abcde',1) from dual;
SUBSTR('ABCDE',1)
-----------------
abcde
SQL> select substr('abcde',2) from dual;
SUBSTR('ABCDE',2)
-----------------
bcde


n<0時,如果|n|<=被截取字符串的長度,
結果為從右向左截取|n|個字符


QUOTE:
SQL> select substr('abcde',-2) from dual;
SUBSTR('ABCDE',-2)
------------------
de
SQL> select substr('abcde',-3) from dual;
SUBSTR('ABCDE',-3)
------------------
cde
SQL> select substr('abcde',-5) from dual;
SUBSTR('ABCDE',-5)
------------------
abcde


如果|n|>被截取字符串的長度,結果為NULL

QUOTE:
SQL> select substr('abcde',-6) from dual;
SUBSTR('ABCDE',-6)
------------------
SQL> select substr('abcde',-60) from dual;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM