热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

循序渐进学Oracle之函数(重点)

单行函数—字符函数虽然各个数据库都是支持SQL语句的,但是每一个数据库也有每一个数据库自己所支持的操作函数,这些就是单行函数,而如果要想进行数据库开发的

单行函数—字符函数虽然各个数据库都是支持SQL语句的,但是每一个数据库也有每一个数据库自己所支持的操作函数,这些就是单行函数,而如果要想进行数据库开发的

单行函数—字符函数

虽然各个数据库都是支持SQL语句的,但是每一个数据库也有每一个数据库自己所支持的操作函数,这些就是单行函数,而如果要想进行数据库开发的话,除了要会使用SQL之外,就是要多学习函数。

单行函数主要分为以下五类:字符函数、数字函数、日期函数、转换函数、通用函数;

1-字符函数:

字符函数的功能主要是进行字符串数据的操作,下面给出几个字符函数:

* UPPER(字符串|列):将输入的字符串变为大写返回;

* LOWER(字符串|列):将输入的字符串变为小写返回;

* INITCAP(字符串|列):开头首字母大写;

* LENGTH(字符串|列):求出字符串的长度;

* REPLACE(字符串|列):进行替换;

*SUBSTR(字符串|列,开始点[结束点]):字符串截取:

Oracle之中有一点比较麻烦,即使要验证字符串,也必须编写完整的SQL语句,所以在Oracle数据库之中为了用户的查询方便,故专门提供了一个“dual”的虚拟表。

范例1:观察转大写的函数

SELECT UPPER('hello') FROM dual ;

范例6:使用字母“_”替换姓名中所有字母“A”的信息;

col REPLACE(ename,'A','_') FORMAT A50 ; SELECT REPLACE(ename,'A','_') FROM emp ;

clip_image014

字符串截取操作有两种语法:

|-语法一:SUBSTPR(字符串|列,开始点),表示从开始点一直截以到结尾;

|-语法二:SUBSTPR(字符串|列,开始点,结束点),表示从开始点一直截以到结束点,截取部分内容;

范例7: 语法一:SUBSTPR(字符串|列,开始点),香港虚拟主机,表示从开始点一直截以到结尾;

SELECT ename,SUBSTR(ename,3) FROM emp ; //从第3个字符开始一直到结尾!

clip_image016

范例8:语法二:SUBSTPR(字符串|列,开始点,结束点),表示从开始点一直截以到结束点,截取部分内容;

SELECT ename,SUBSTR(ename,0,3) FROM emp ; //截取前3个字符! SELECT ename,SUBSTR(ename,1,3) FROM emp ; //截取前3个字符!

clip_image018

clip_image020

范例9:要求截取每个雇员姓名的后三个字母;

* 正常思路:通过长度-2确定开始点

SELECT ename,SUBSTR(ename,LENGTH(ename)-2) FROM emp ;

* 新思路:设置负数,表示从后指定截取位置

SELECT ename,SUBSTR(ename,-3) FROM emp ;

clip_image022

clip_image024

面试题:

1、请问SUBSTR()函数截取的时候下标是从0,还是从1开始?

* 在Oracle数据库之中,SUBSTR()函数从0或1开始都是一样的;(见范例8)

* SUBSTR()函数也可以设置为负数,表示由后指定截取开始点;(见范例9)

2-数字函数
数字函数一共有3个:

* ROUND(数字|列[,保留小数的位数]):四舍五入的操作;

* TRUNC(数字|列[,保留小数的位数]):舍弃指定位置的内容;

* MOD(数字1,数字2):取模,取余数;

范例10:验证ROUND()函数

SELECT ROUND(903.5) FROM dual ;

clip_image026

SELECT ROUND(903.5),ROUND(-903.53567) FROM dual ; SELECT ROUND(903.5),ROUND(-903.53567),ROUND(903.53567,-1) FROM dual ; SELECT ROUND(903.5),ROUND(-903.53567),ROUND(903.53567,-1),ROUND(903.53567,2) FROM dual ;//保留2位

clip_image028

范例11:验证TRUNC()函数

SELECT TRUNC(903.5),TRUNC(-903.53567),TRUNC(903.53567,-1),TRUNC(903.53567,2) FROM dual ;

clip_image030

范例12:验证MOD()函数

SELECT MOD(10,3) FROM dual ;

clip_image032

以上的三个主要的数学函数,在学习Java中也会有相匹的内容!

2-日期函数

如果现在要想进行日期的操作,则首先有一个必须要解决的问题,就是如何取得当前的日期, 这个当前日期可使用“SYSDATE”取得,代码如下:

SELECT SYSDATE FROM dual ;

clip_image034

范例13:除了以上的当前日期之外,在日期中也可以进行若干计算:

* 日期 + 数字 = 日期,表示若干天之后的日期;

SELECT SYSDATE+3,SYSDATE+300 FROM dual ;

* 日期 - 数字 = 日期,表示若干天前的日期;

SELECT SYSDATE-3,SYSDATE-300 FROM dual ;

* 日期 – 日期 = 数字,表示的是两个日期的天数,但是肯定是大日期 – 小日期;

范例14:求出每个雇员到今天为止的雇佣天数;

SELECT ename,hiredate,SYSDATE-hiredate FROM emp ;

clip_image036

clip_image038

注:而且很多编程语言之中,也都会提出一种概念,日期可以通过数字表示出来!

除了以上三个公式之外,网站空间,也提供了以下四个操作函数:

* LAST_DAY(日期):求出指定日期的最后一天;

范例15:求出本月的最后一天日期

SELECT LAST_DAY(SYSDATE) FROM dual ;

* NEXT_DAY(日期,星期数):求出下一个指定星期X的日期;

范例16:求出下一个周一

SELECT NEXT_DAY(SYSDATE,'星期一') FROM dual ;

* ADD_MONTHS(日期,数字):求出若干月之后的日期;

范例17:求出4个月后是何时

SELECT ADD_MONTHS(SYSDATE,4) FROM dual ;

* MONTHS_BETWEEN(日期1,日期2):求出两个日期之间所经历的月份;

范例18:求出每个雇员到今天为止的雇佣月份;

SELECT ename,hiredate,MONTHS_BETWEEN(SYSDATE,hiredate) FROM emp ; SELECT ename,hiredate,TRUNC(MONTHS_BETWEEN(SYSDATE,hiredate)) FROM emp ;

clip_image040

clip_image042

在所有的开发之中,如果是日期的操作,建议使用以上函数,因为这些函数可以避免闰年的问题。

4-转换函数(核心)

现在已经接触到了Oracle数据库之中的三种数据:数字(NUMBER)、字符串(VACHAR2)、日期(DATE),转换函数的主要功能是完成这几种数据间的相互转换的操作,一共有三种转换函数:

* TO_CHAR(字符串|列,格式字符串):将日期或者是数字变为字符串显示;

* TO_DATE(字符串,格式字符串):将字符串变为DATE数据显示;

* TO_NUMBER(字符串):将字符串变为数字显示;

1、TO_CHAR()函数

在之前查询过当前的系统日期时间:

SELECT SYSDATE FROM dual ;

这个时候是按照“日-月-年”的格式显示,很明显此格式不符合于正常的思路,正常是“年-月-日”,

推荐阅读
  • 本文介绍了在SQL中查询分组后每组行数的统计方法。通过使用count()函数和GROUP BY子句可以统计每组的行数,但是如何统计所有组的行数呢?本文提供了一种实现方法,并给出了相应的SQL查询语句。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文介绍了adg架构设置在企业数据治理中的应用。随着信息技术的发展,企业IT系统的快速发展使得数据成为企业业务增长的新动力,但同时也带来了数据冗余、数据难发现、效率低下、资源消耗等问题。本文讨论了企业面临的几类尖锐问题,并提出了解决方案,包括确保库表结构与系统测试版本一致、避免数据冗余、快速定位问题等。此外,本文还探讨了adg架构在大版本升级、上云服务和微服务治理方面的应用。通过本文的介绍,读者可以了解到adg架构设置的重要性及其在企业数据治理中的应用。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了使用postman进行接口测试的方法,以测试用户管理模块为例。首先需要下载并安装postman,然后创建基本的请求并填写用户名密码进行登录测试。接下来可以进行用户查询和新增的测试。在新增时,可以进行异常测试,包括用户名超长和输入特殊字符的情况。通过测试发现后台没有对参数长度和特殊字符进行检查和过滤。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • MyBatis错题分析解析及注意事项
    本文对MyBatis的错题进行了分析和解析,同时介绍了使用MyBatis时需要注意的一些事项,如resultMap的使用、SqlSession和SqlSessionFactory的获取方式、动态SQL中的else元素和when元素的使用、resource属性和url属性的配置方式、typeAliases的使用方法等。同时还指出了在属性名与查询字段名不一致时需要使用resultMap进行结果映射,而不能使用resultType。 ... [详细]
author-avatar
ouyan1985_998
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有