文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

oracle 函数学习 Oracle10g学习系列(7)

2024-04-02 19:55

关注

Oracle函数有字符函数、数学函数、日期函数和转换函数。我只了解了字符函数和数学函数。


一、字符函数


lower(char)  将字符串转化为小写的格式

SQL> select lower(ename),ename from emp;

LOWER(ENAME) ENAME

------------ ----------

smith        SMITH

allen        ALLEN

ward         WARD


upper(char)  将字符串转化为大写的格式

SQL> select upper(ename),ename from emp;

UPPER(ENAME) ENAME

------------ ----------

SMITH        SMITH

ALLEN        ALLEN

WARD         WARD


initcap(char)将字符串首字母转化为大写的格式

SQL> select initcap(ename),ename from emp;

INITCAP(ENAME) ENAME

-------------- ----------

Smith          SMITH

Allen          ALLEN

Ward           WARD


substr(char,m,n) 取字符串的子串,从第2位开始取,取3位。m是从第m个开始取,取字符串的子串n代表取n个的意思,不是代表取到第n个

SQL> select substr(ename,2,3),ename from emp;

SUBSTR(ENAME,2,3) ENAME

----------------- ----------

MIT               SMITH

LLE               ALLEN

ARD               WARD


length(char) 返回字符串的长度,HelloWorld一共有10位。截取了ename等于5的名字,只有两个ward的长度是4,所以没有列出来

SQL> select length('HelloWorld') from tb2;

LENGTH('HELLOWORLD')

--------------------

                  10


SQL> select ename from emp where length(ename)=5;

ENAME

------------------------------

SMITH

ALLEN


replace(char1,search_string,replace_string) 替换函数,把A替换成bob

SQL> select replace(ename,'A','bob'),ename from emp;

REPLACE(ENAME,'A','BOB')       ENAME

------------------------------ ----------

SMITH                          SMITH

bobLLEN                        ALLEN

WbobRD                         WARD


instr(char1,char2,[,n[,m]])取子串在字符串的位置,W在第6个位置

SQL> select instr('HelloWorld','W') from tb2;

INSTR('HELLOWORLD','W')

-----------------------

                      6



二、数学函数:

数学函数的输入参数和返回值的数据类型都是数字类型的。对数字的处理,在财务系统或银行系统中用的最多,不同的处理方法,对财务报表有不同的结果。数学函数包括cos,cosh,exp,ln, log,sin,sinh,sqrt,tan,tanh,acos,asin,atan,round,这里讲最常用的:



round(n,[m])该函数用于执行四舍五入,如果省掉m,则四舍五入到整数,如果m是正数,则四舍五入到小数点的m位后。如果m是负数,则四舍五入到小数点的m位前。 


四舍五入到第1位

SQL>select round(sal),sal from emp;

ROUND(SAL)       SAL

---------- ---------

       800    800.34

      1601   1600.56

      1251   1250.78


SQL>select round(sal,1),sal from emp;

ROUND(SAL)       SAL

---------- ---------

       800.3    800.34

      1600.6   1600.56

      1250.8   1250.78


SQL>select round(sal),sal from emp;

ROUND(SAL)       SAL

---------- ---------

       800    800.34

      1600   1600.56

      1250   1250.78


SQL>select round(sal,1),sal from emp;

ROUND(SAL)       SAL

---------- ---------

       800.3    800.34

      1600.5   1600.56

      1250.7   1250.78


左侧1位四舍五入

SQL> select round(211.5, -1) from dual;

ROUND(211.5,-1)

---------------

            210


SQL> select round(215.5, -1) from dual;

ROUND(215.5,-1)

---------------

            220


左侧2位四舍五入

SQL> select round(211.5, -2) from dual;

ROUND(211.5,-2)

---------------

            200


SQL> select round(261.5, -2) from dual;

ROUND(261.5,-2)

---------------

            300


trunc(n,[m]) 该函数用于截取数字。如果省掉m,就截去小数部分,如果m是正数就截取到小数点的m位后,如果m是负数,则截取到小数点的前m位。 

SQL> select trunc(45.923,2),trunc(45.923),trunc(45.923,-2) from dual;


TRUNC(45.923,2) TRUNC(45.923) TRUNC(45.923,-2)

--------------- ------------- ----------------

          45.92            45                0


SQL> select trunc(45.923,2),trunc(45.923),trunc(45.923,-1) from dual;


TRUNC(45.923,2) TRUNC(45.923) TRUNC(45.923,-1)

--------------- ------------- ----------------

          45.92            45               40


mod(m,n),求余数。取值是m/n的余数

SQL> select mod(10,2) from dual;

 MOD(10,2)

----------

         0


floor(n) 返回小于或是等于n的最大整数

SQL> select floor(sal),sal from tb2;

FLOOR(SAL)        SAL

---------- ----------

       500     500.34

       500     500.56

       585     585.56


ceil(n) 返回大于或是等于n的最小整数

SQL> select ceil(sal),sal from tb2;

 CEIL(SAL)        SAL

---------- ----------

       501     500.34

       501     500.56

       586     585.56


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯