我们都知道Oracle函数在实际的应用中比较广泛,对其的实际操作与其相关功能也是颇为熟悉,但是你了解Oracle函数怎样使将字符串装换为小写的格式的具体操作吗?如果你有兴趣的话你就可以浏览以下的文章。

Oracle函数:

Lower(char):将字符串装换为小写的格式

Upper(char):将字符串装换为大写的格式

length(char):返回字符串的长度

substr(char,m,n):从m开始截取n个字符串

1)查询emp表,名字用小写显示:

  1. select lower(ename) from emp ;

2)查询名字的长度是5个字符的员工:

  1. select * from emp where length(ename)=5;

3)

  1. select substr(ename,2,3) from emp;

这样,SMITH就变成了MIT

4)使名字的第一个字符大写,其它字符小写:

  1. select upper(substr(ename,1,1))
    ||lower(substr(ename,2,length(ename)-1)) from emp;

||:这个符号在Oracle中是个连接符,就像Java中用“+”连接两个String类型的字串一样。

5)

  1. select replace(ename,'A','a') from emp;

把ename字段中的所有‘A’替换成‘a’,当然,这样替换之后仅仅是对查询结果的显示起了作用,不会真的在数据库中作替换的

6)to_date函数

  1. insert into myemp values(7903,'MORFLAME','ANALYST'
    ,7566,to_date('1988-1-1','yyyy-mm-dd'),2345.23,555.55,20);

本来Oracle的默认日期格式是‘01-1月-1988’,如果不习惯,那么在做插入的时候就可以使用这个Oracle函数来用我们喜欢的日期格式做插入,比如to_date(‘1988/1/1’,’yyyy/mm/dd’),这也是可以的。

7)round函数:四舍五入求值

  1. SQL> select round(sal),sal from myemp where ename=

2 'MORFLAME';

ROUND(SAL) SAL

2345 2345.23

还可以控制小数的位数:

  1. select round(sal,1),sal from myemp where ename='MORFLAME';
  2. ROUND(SAL,1) SAL
  3. 2345.2 2345.23

8)trunc函数:不四舍五入,直接舍掉

  1. SQL> select trunc(comm,1),comm from myemp where ename='MORFLAME';
  2. TRUNC(COMM,1) COMM
  3. 555.5 555.55

第二个参数是-1的情况

  1. SQL> select round(comm,-1),comm from myemp where ename='MORFLAME';
  2. ROUND(COMM,-1) COMM
  3. 560 555.55

9)ceil函数:求比某个数大的最小整数

  1. SQL> select ceil(comm),comm from myemp where ename='MORFLAME';
  2. CEIL(COMM) COMM
  3. 556 555.55

10)floor函数:求比某个数小的最大整数

  1. SQL> select floor(comm),comm from myemp where ename='MORFLAME';
  2. FLOOR(COMM) COMM
  3. 555 555.55

11)取模函数mod

  1. SQL> select mod(12,3) from dual;

--此处的dual表是个虚拟表,仅仅用来测试Oracle函数而已。

MOD(12,3)

0

12)abs,求绝对值函数

  1. SQL> select abs(-3) from dual;

ABS(-3)

以上的相关内容就是对Oracle函数的介绍,望你能有所收获。

引用原文:http://www.cnblogs.com/chinafine/archive/2010/12/07/1898699.html

写博客是为了记住自己容易忘记的东西,另外也是对自己工作的总结,文章可以转载,无需版权。希望尽自己的努力,做到更好,大家一起努力进步!

如果有什么问题,欢迎大家一起探讨,代码如有问题,欢迎各位大神指正!

05-11 19:54