码迷,mamicode.com
首页 > 数据库 > 详细

oracle字符函数

时间:2015-10-27 15:26:51      阅读:185      评论:0      收藏:0      [点我收藏+]

标签:函数

1,字符串截取
   select substr(‘abcdef‘,1,3) from dual

2,查找子串位置
   select instr(‘abcfdgfdhd‘,‘fd‘) from dual

3,字符串连接
   select ‘HELLO‘||‘hello world‘ from dual;

4, 1)去掉字符串中的空格
    select ltrim(‘ abc‘) s1,
    rtrim(‘zhang ‘) s2,
    trim(‘ zhang ‘) s3 from dual

   2)去掉前导和后缀
    select trim(leading 9 from 9998767999) s1,
    trim(trailing 9 from 9998767999) s2,
    trim(9 from 9998767999) s3 from dual;

5,返回字符串首字母的Ascii值
   select ascii(‘a‘) from dual

6,返回ascii值对应的字母
   select chr(97) from dual

7,计算字符串长度 
   select length(‘abcdef‘) from dual

8,initcap(首字母变大写) ,lower(变小写),upper(变大写)
   select lower(‘ABC‘) s1,  
       upper(‘def‘) s2, 
       initcap(‘efg‘) s3
   from dual; 

9,Replace
   select replace(‘abc‘,‘b‘,‘xy‘) from dual;

10,translate
   select translate(‘abc‘,‘b‘,‘xx‘) from dual; -- x是1位

11, decode[实现if ..then 逻辑]   注:第一个是表达式,最后一个是不满足任何一个条件的值
   select deptno,decode(deptno,10,‘1‘,20,‘2‘,30,‘3‘,‘其他‘) from dept;
   例:
   select seed,account_name,decode(seed,111,1000,200,2000,0) from t_userInfo//如果seed为111,则取1000;为200,取2000;其它取0
   select seed,account_name,decode(sign(seed-111),1,‘big seed‘,-1,‘little seed‘,‘equal seed‘) from t_userInfo//如果seed>111,则显示大;为200,则显示小;其它则显示相等

12, case[实现switch ..case 逻辑]
SELECT CASE X-FIELD 
         WHEN X-FIELD < 40 THEN ‘X-FIELD 小于 40‘
         WHEN X-FIELD < 50 THEN ‘X-FIELD 小于 50‘
         WHEN X-FIELD < 60 THEN ‘X-FIELD 小于 60‘
         ELSE ‘UNBEKNOWN‘
        END
   FROM DUAL

注:CASE语句在处理类似问题就显得非常灵活。当只是需要匹配少量数值时,用Decode更为简洁

原文地址:http://plat.delit.cn/thread-191-1-1.html

转载请注明出处:

撰写人:度量科技http://www.delit.cn

oracle字符函数

标签:函数

原文地址:http://delit.blog.51cto.com/5487020/1706740

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!