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;

sql常用函数instr()和substr()的更多相关文章

  1. [转载]oracle的常用函数 instr() 和substr()函数

    在Oracle中 可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符. 在一个字符串中查找指定的字符,返回被查找到的指定的字符的位置. 语法: instr(sourceString, ...

  2. oracle的常用函数 instr() 和substr()函数

    from:http://1055592535.iteye.com/blog/1676235 在Oracle中 可以使用instr函数对某个字符串进行判断,判断其是否含有指定的字符. 在一个字符串中查找 ...

  3. SQL常用函数总结

    SQL常用函数总结 这是我在项目开发中使用db2数据库写存储过程的时候经常用到的sql函数.希望对大家有所帮助: sql cast函数 (1).CAST()函数的参数是一个表达式,它包括用AS关键字分 ...

  4. oracle学习笔记(九) SQL常用函数说明以及使用

    SQL常用函数说明以及使用 以下补充以下常用的函数,更多的请看oracle函数API文档 to_char to_char(8.58,'9.99') to_char(8.50,'9.00') to_ch ...

  5. ylb:SQL 常用函数

    ylbtech-SQL Server: SQL Server-SQL 常用函数 1,数学函数 2,日期和时间函数 3,字符串函数 4,转换函数 1,ylb:SQL 常用函数返回顶部 1,数学函数 2, ...

  6. SQL常用函数之五 str()

    原文:SQL常用函数之五 str() 使用str函数   :STR 函数由数字数据转换来的字符数据.   语法      STR    (    float_expression    [    ,  ...

  7. [转]SQL 常用函数及示例

    原文地址:http://www.cnblogs.com/canyangfeixue/archive/2013/07/21/3203588.html --SQL 基础-->常用函数 --===== ...

  8. SQL 常用函数及示例

    --SQL 基础-->常用函数 --================================== /* 一.函数的分类 SQL函数一般分为两种 单行函数 基于单行的处理,一行产生一个结果 ...

  9. SQL常用函数

    SQL中常用的函数有类型转换函数.字符串函数和日期使用函数.更多具体的函数用法参见DBMS中的帮助文档. 类型转换函数 cast(值 as 类型) update 表名 set 列1=列1+cast(列 ...

随机推荐

  1. .net iis6中配置伪静态

    1.右键点击 要设置网站的网站 2.属性 ——>主目录 ——>配置——> 3.如右侧窗口,找到 .aspx 扩展名——>编辑——>复制 可执行文件的路径——>关闭 ...

  2. one + two = 3

    读入两个小于100的正整数A和B,计算A+B.需要注意的是:A和B的每一位数字由对应的英文单词给出. 输入 测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =", ...

  3. vue 2.6 更新变动

    [原文链接] Slots:新语法,性能改进为3.0做准备改用 v-slot 指令 //默认插槽 <baz v-slot ="baz"> {{baz}} </ ba ...

  4. Python中的循环体

    一.循环 1.while语句: while 条件: 循环体 else: 当上面的条件不成立时才会执行 执行顺序:判断条件是否为真.如果为真,执行循环体,再次判断条件如果为假,执行else下代码块 2. ...

  5. AngularJS 指令解析(一)

    AngularJS 指令解析(一) 前言 笔者AngularJS接触时间差不多是两年多,虽然这两年多AngularJS版本日新月异,但是笔者的版本是比较老的1.4.3,一方面是自己对这个版本比较熟悉, ...

  6. Eclipse常用设置和快捷键

    1.提示键配置一般默认情况下,Eclipse ,MyEclipse 的代码提示功能是比Microsoft Visual Studio的差很多的,主要是Eclipse ,MyEclipse本身有很多选项 ...

  7. Form 头行附件查询

    查询Form的头行附件: SELECT  st.short_text order_short_text, description order_attach_desc, pk1_value order_ ...

  8. jquery 滑块导航菜单

    带滑块的导航菜单,鼠标悬浮时,滑块会移动至鼠标位置,离开时,滑块会回到原来的位置,点击菜单之后滑块会停留在被点击菜单位置,等待下一次的鼠标悬浮事件或者点击事件,效果图: 图片效果不行,直接上代码: & ...

  9. Android 修改圆形progressBar颜色

    查了半天资料,没查到怎样修改progressBar的方法,全都是重新写个ProgressBar,其实很简单在只要一句xml里一句化就可以 android:indeterminateTint=" ...

  10. ansible使用2-命令

    并发与shell # bruce用户身份,-m指定模块名称,默认模块名command,all所有目标主机,也可以指定组名或者主机名 ansible all -m ping -u bruce # bru ...