可以使用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;

instr和substr函数相关推荐

  1. Mysql中INSTR(str, substr)函数

    函数介绍 INSTR(str, substr):返回子串substr在字符串str中的第一个出现的位置,如果存在则返回1~N,不存在返回0,任意一个字符串为NULL则返回NULL. 函数实例 INST ...

  2. oracle取第一位,Oracle中的substr()函数和INSTR()函数

    1)substr函数格式   (俗称:字符截取函数) 格式1: substr(string string,int a,int b); 格式2:substr(string string,int a) ; ...

  3. oracle8i substr,Oracle中的INSTR,NVL和SUBSTR函数的用法详解

    Oracle中INSTR的用法: INSTR方法的格式为 INSTR(源字符串, 要查找的字符串, 从第几个字符开始, 要找到第几个匹配的序号) 返回找到的位置,如果找不到则返回0. 例如:INSTR ...

  4. ORACLE SUBSTR函数和INSTR函数的结合

    ORACLE SUBSTR函数和INSTR函数的结合 编写脚本时,经常会用到SUBSTR函数和INSTR函数结合使用,往往会出现"意想不到"的效果,这里不再介绍SUBSTR函数和I ...

  5. Oracle截取字符串:instr、substr、length函数的使用

    1.字段中有以下字符串数据: 张三(zhangsan) 2.截取代码 ps:我的数据库表名为"shuizhu_test",该字段名为"username",详细请 ...

  6. Oracle中INSTR和SUBSTR的用法

    2019独角兽企业重金招聘Python工程师标准>>> Oracle中INSTR和SUBSTR的用法 Oracle中INSTR的用法: INSTR方法的格式为 INSTR(源字符串, ...

  7. dbms_lob包学习笔记之三:instr和substr存储过程

    instr和substr存储过程,分析内部大对象的内容instr函数与substr函数 instr函数用于从指定的位置开始,从大型对象中查找第N个与模式匹配的字符串. 用于查找内部大对象中的字符串的i ...

  8. python substr函数_Sql SUBSTR函数

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

  9. oracle substr(table),oracle中的substr()函数

    SUBSTR(cExpression,nStartPosition [,nCharactersReturned]) 其中,cExpression指定要从其中返回字符串的字符表达式或备注字段: nSta ...

  10. oracle8i substr,Oracle中INSTR和SUBSTR的用法

    Oracle中INSTR和SUBSTR的用法 Oracle中INSTR的用法: INSTR方法的格式为 INSTR(源字符串, 要查找的字符串, 从第几个字符开始, 要找到第几个匹配的序号) 返回找到 ...

最新文章

  1. C#笔记2__Char类、String类、StringBuilder类 / 正则表达式 /
  2. Go语言在Linux环境下输出彩色字符
  3. 【讨论】关于什么时候使用module,什么时候使用class
  4. 数学课本上的几大变态之处
  5. GitHub 发布了一款重量级产品,可直接运行代码
  6. 论文浅尝 | 主题感知的问答生成
  7. 腾讯云数据库Redis助力百万企业远程办公
  8. Linux下多功能编辑器,Linux下的编辑器——vi大全
  9. 自动化调参NNI学习(三):使用python启动NNI框架调整随机森林(RandomForest)模型
  10. Rails UVA - 514(栈)
  11. 移动一个网站集所使用的内容数据库
  12. 说说VNode节点(Vue.js实现)
  13. 【hdu1506/牛客小A的柱形图】单调栈入门题目
  14. python soup findall 第几个元素_BeautifulSoup库findAll()、find()方法详解
  15. rpg服务器修改数据,ATOM RPG 修改数据方法 怎么修改游戏数据-游侠网
  16. jxls遍历list时使用模板的批注语法
  17. 【VBA】excel客户数据打印录入控件
  18. fingerprint模块管理指纹识别
  19. 观《蓝天铁翼-红旗军演》所想到的
  20. hash与history 以及区别

热门文章

  1. 【English】十六、时间相关
  2. 产品研发流程与周期(非原创)
  3. angular4自定义组件非input元素实现ngModel双向数据绑定(转载)
  4. mac下安装nginx及相关配置
  5. 获取页面iframe里的元素
  6. 粉刷匠(bzoj 1296)
  7. js获取单选按钮选项
  8. 在ASP.NET的服务器端使用message box(Message box Server side in ASP.Net)
  9. webpack官方文档分析(一):安装
  10. 【转】博客美化(5)为博客或系统添加一个强大的评论系统