Oracle_INSTR函数使用

    在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置。只检索一次,就是说从字符的开始到字符的结尾就结束。 
  语法如下: 
  instr( string1, string2 [, start_position [, nth_appearance ] ] ) 
  参数分析: 
  string1 
  源字符串,要在此字符串中查找。 
  string2 
  要在string1中查找的字符串
  start_position 
  示例:

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

  工作中的一种常用用法:

    可以这样运用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%' ; 

猜你喜欢

转载自wang-z-p2007.iteye.com/blog/2152782
今日推荐