oracle instr 妙用 (SQL 语句)

这是存在此要求时可这样使用

若有如下情情况

dm          content

1     

11           ertre

12           4345

13           fgs

14           435

15           345

可以用 select content from where instr(dm, 传入的参数)=1;

获取 当dm为1 时 可得

11           ertre

12           4345

13           fgs

14           435

15           345

当  dm=11时 得

11       ertre

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

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

 

posted @ 2012-05-30 21:27  diwer  阅读(885)  评论(0编辑  收藏  举报