Oracle单行函数学习

SQL函数有单行函数和多行函数,我们这里介绍的为单行函数

单行函数:

  1. 操作数据对象
  2. 接受参数并返回一个结果
  3. 可转换数据类型,还能嵌套
  4. 参数可以是一个列或一个值
  5. 特征是:只对一行进行交换,每行返回一个结果。

我们将用Oracle提供的SQL Plus 进行示例,登录的用户为Oracle提供的有基础表的scott用户

【1】字符型单行函数

lower():

把字符串转为小写

我们使用dual不存在的表作为占位,只用于演示函数效果,不用于数据查询

将lower()中的大写字符串转为小写------"hshs"


upper():

把字符串转为大写

将upper()中的小写字符串转为大写------"HSHS"


inticap():

把字符串首字母转为大写

将inticap()中的字符串首字母转为大写------"Apple"


concat():

连接两个字符或两个列

也可以连接字段

当然也可以把字符串和字段连接起来


substr():

截取字符串

3:表示从某个位置开始截取,上图是从第三个位置开始

2:表示截取多长的字符串,上图是截取两个


length():

计算字符串的字符个数,空格也包含

将空格包含在内,总长度为7


instr():

在字符串中搜索子字符串的位置

搜索字符串中"cd"的位置,位置为3


replace():

把字符串中的某个子字符串替换成另一个子字符串

将字符串中的"cd"替换为"dc"


【2】数字型单行函数

round(num,n):

对num指定n位小数,会四舍五入

对数字精确到2位小数,且四舍五入


trunc(num,n):

对num指定n位小数,不四舍五入

对数字精确到2为小数,且不四舍五入


mod():

求两个数相除的余数

5除以3,余数为2


【3】日期时间函数

sysdate:

获取系统当前时间,格式为日期-月份-年份,年份仅显示后两位,如2025年显示25

也可以和一个数字相加减,这个数字代表天数

在今天的日期+1天,如果输入的是小时数,则除以24

因为SQL Plus暂不显示时/分/秒,我们使用SQL Developer演示

sql 复制代码
select sysdate+20/24 from dual;

效果为下图**↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓**:


计算两个日期的差值:

使用to_date()输入需要计算差值的日期,,格式为日期-月份-年份,输入月份时需要先查看系统的日期格式,下面我们先用英文月份进行演示

报出错误:无效的月份,意味着我们系统的日期格式并不是英文,接下来我们来查看当前会话自己系统的日期格式是什么,使用userenv('lang')

查询出的结果为"ZHS",意思是当前会话系统的日期格式是中文,那我们修改写法,将月份替换为中文

结果为2026/2/20距离2026/4/1多少天,相差约40天,当然也可将sysdate写在前面,to_date写在后面


【4】空值和空值处理函数

什么是空值:

在数据库中没有定义,没有确定性意义的一类值,用 is null 或 is not null 判断


nvl(num,num1):

如果num为空值,则返回num1,否则返回num

下面使用有数据的表emp进行演示,下方是表的结构和数据

查询ename,job,以及comm列,对comm列使用nvl()函数,如果有空值,返回0,不为空就返回comm本身的值,返回的值也可自己定义,下方示例空值返回为0


nvl2(num,num1,num2):

如果num为空值,则返回num2,否则返回num1

依然是使用同nvl()相同的示例,如果comm为空返回0,不为空返回comm本身,同nvl()一样,返回的值也可自定义,下方示例空值返回为0

相关推荐
Polar__Star9 小时前
如何在 AWS Lambda 中正确使用临时凭证生成 S3 预签名 URL
jvm·数据库·python
Lucifer三思而后行9 小时前
zCloud 中 Oracle 实例状态未知问题记录
数据库·oracle
island13149 小时前
最详细VMware Workstation 17 上安装 Ubuntu 系统
linux·数据库·ubuntu
卢傢蕊9 小时前
MongoDB
数据库·mongodb
m0_743623929 小时前
React 自定义 Hook 的命名规范与调用规则详解
jvm·数据库·python
古城小栈10 小时前
GORM 操作 PostgreSQL 高级类型
数据库·postgresql
ward RINL10 小时前
redis分页查询
数据库·redis·缓存
Treh UNFO10 小时前
Redis-配置文件
数据库·redis·oracle
iNgs IMAC10 小时前
Redis之Redis事务
java·数据库·redis
oLLI PILO10 小时前
Redis连接池
数据库·redis·缓存