• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >oracle > Oracle中instr函数使用方法

Oracle中instr函数使用方法

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了oracle instr函数,oracle中instr函数,oracle中instr,oracle instr,oracle regexp instr等相关知识,希望本文的分享对您有所帮助
INSTR (源字符串, 目标字符串, 起始位置, 匹配序号)

  在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置。只检索一次,就是说从字符的开始到字符的结尾就结束。

  语法如下:
  instr( string1, string2 [, start_position [, nth_appearance ] ] )
  参数分析:
  string1
  源字符串,要在此字符串中查找。
  string2
  要在string1中查找的字符串.
  start_position

  代表string1 的哪个位置开始查找。此参数可选,如果省略默认为1. 字符串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字符串在源字符串中的开始索引。

  nth_appearance

  代表要查找第几次出现的string2. 此参数可选,如果省略,默认为 1.如果为负数系统会报错。

  注意:

  如果String2在String1中没有找到,instr函数返回0.

  示例:

  SELECT instr('syranmo','s') FROM dual; -- 返回 1
  SELECT instr('syranmo','ra') FROM dual; -- 返回 3
  SELECT instr('syran mo','a',1,2) FROM dual; -- 返回 0

  (根据条件,由于a只出现一次,第四个参数2,就是说第2次出现a的位置,显然第2次是没有再出现了,所以结果返回0。注意空格也算一个字符!)

  SELECT instr('syranmo','an',-1,1) FROM dual; -- 返回 4

  (就算是由右到左数,索引的位置还是要看‘an'的左边第一个字母的位置,所以这里返回4)

  SELECT instr('abc','d') FROM dual; -- 返回 0

  注:也可利用此函数来检查String1中是否包含String2,如果返回0表示不包含,否则表示包含。
  对于上面说到的,我们可以这样运用instr函数。请看下面示例:

  如果我有一份资料,上面都是一些员工的工号(字段:CODE),可是我现在要查询出他们的所有员工情况,例如名字,部门,职业等等,这里举例是两个员工,工号分别是'A10001′,'A10002′,其中假设staff是员工表,那正常的做法就如下:

  SELECT code , name , dept, occupation FROM staff WHERE code IN ('A10001','A10002');

  或者:

  SELECT code , name , dept, occupation FROM staff WHERE code = 'A10001' OR code = 'A10002';

  有时候员工比较多,我们对于那个'觉得比较麻烦,于是就想,可以一次性导出来么?这时候你就可以用instr函数,如下:

  SELECT code , name , dept, occupation FROM staff WHERE instr('A10001,A10002',code)>0;

  查询出来结果一样,这样前后只用到两次单引号,相对方便点。

  还有一个用法,如下:

  SELECT code, name, dept, occupation FROM staff WHERE instr(code, '001') > 0;
  等同于
  SELECT code, name, dept, occupation FROM staff WHERE code LIKE '%001%' ;

Oracle的instr函数使用实例

INSTR方法的格式为
INSTR(src, subStr,startIndex, count)
src: 源字符串
subStr : 要查找的子串
startIndex : 从第几个字符开始。负数表示从右往左查找。
count: 要找到第几个匹配的序号
返回值: 子串在字符串中的位置,第1个为1;不存在为0. (特别注意:如果src为空字符串,返回值为null)。

用法举例:

最简单的一种,查找l字符,首个l位于第3个位置。
SQL> select instr('hello,java world', 'l') from dual;

INSTR('HELLO,JAVAWORLD','L')
----------------------------
3

查找l字符,从第4个位置开始。
SQL> select instr('hello,java world', 'l', 4) from dual;
INSTR('HELLO,JAVAWORLD','L',4)
------------------------------
4

查找l字符,从第1个位置开始的第3个
SQL> select instr('hello,java world', 'l', 1, 3) from dual;
INSTR('HELLO,JAVAWORLD','L',1,
------------------------------
15

查找l字符,从右边第1个位置开始,从右往左查找第3个(也即是从左到右的第1个)
SQL> select instr('hello,java world', 'l', -1, 3) from dual;
INSTR('HELLO,JAVAWORLD','L',-1
------------------------------
3
找不到返回0
SQL> select instr('hello,java world', 'MM') from dual;
INSTR('HELLO,JAVAWORLD','MM')
-----------------------------
0

源字符为空字符串''的情况
i is empty </div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Oracle中的INSTR,NVL和SUBSTR函数的用法详解
  • oracle使用instr或like方法判断是否包含字符串
  • Oracle中instr函数使用方法

相关文章

  • 2017-05-11讲解Oracle数据库中的数据字典及相关SQL查询用法
  • 2017-05-11通过sql准确查出一天数据的方法
  • 2017-05-11PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法
  • 2017-05-11oracle错误代码大全(超详细)
  • 2017-08-22Oracle报错:ORA-28001: 口令已经失效
  • 2017-05-11Window下Oracle安装图文教程
  • 2017-05-11Oracle关于时间/日期的操作
  • 2017-05-11日常收集整理oracle trunc 函数处理日期格式(很实用)
  • 2017-05-11oracle数据库导入导出命令使用方法
  • 2017-05-11在Mac OS上安装Oracle数据库的基本方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 45个非常有用的 Oracle 查询语句小结
    • Oracle删除重复的数据,Oracle数据去重复
    • CentOS系统上安装配置Oracle数据库的详细教程
    • Oracle生成单据编号存储过程的实例代码
    • VMware中linux环境下oracle安装图文教程(二)ORACLE 10.2.05版本的升级补丁安装
    • oracle应用程序实现打包 的方法
    • Hibernate Oracle sequence的使用技巧
    • Oracle 查看表空间的大小及使用情况sql语句
    • oracle数据迁移到db2数据库的实现方法(分享)
    • 查看oracle数据库的编码及修改编码格式的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有