文档章节

Oracle使用简单函数

kukudeku
 kukudeku
发布于 2016/06/18 09:16
字数 1905
阅读 9
收藏 0
点赞 0
评论 0

本章将介绍Oracle数据库的内置函数。函数可以接受零个或多个参数,并返回一个输出参数。在Oracle数据库中可以使用两种主要类型的参数:

  • 单行函数(single row function)单行函数同时只能对一行进行操作,且对输入的每一行返回一行输出结果。单行函数的示例是CONCAT(x,y),其功能是将y添加到x上,并返回所得到的字符串

  • 聚合函数(aggregate function)聚合函数同时可以对多行进行操作,并返回一行输出结果。聚合函数的一个例子是AVG(x),其功能是返回x的平均值,其中x可以是一列,或者说一个表达式

  1. 使用单行函数。单行函数主要有5种:

    1. 字符函数。可以对由字符组成的字符串进行操作

    2. 数字函数。可以对数字进行计算

    3. 转换函数。可以将一种数据库类型转换成另一中数据库类型

    4. 日期函数。可以对日期和时间进行处理

    5. 正则表达式函数。在查询数据时可以使用正则表达式

1.1 字符函数

字 符 函 数 列 表

函数 说明
ASCII(x) 返回字符x的ASCII码
CHR(x) 返回ASCII码为x的字符
CONCAT(x,y) 将y添加到x上,并将得到的字符串作为结果返回
INITCAP(x) 将x中每个单词的首字母都转换成大写,并返回处理结果
INSET(x,find_string[,start][,occurentce]) 在x中查找字符串find_string,然后返回find_string所在的位置。可以提供一个可选的start位置来指定该函数从这个位置开始查找。同样,也可以指定一个可选的occurrence参数来说明应该返回find_string第几次出现的位置
LENGTH(x) 返回x字符串的长度
LOWER(x)

1.2 数字函数

    数字函数可以用于计算。数字函数可以接受输入的数字参数,这些数字可以来自一个表的数字列,也可以是一个结果为数字的表达式。数字函数会对这些输入的数字进行计算返回一个数字结果。数字函数的一个例子是SQRT(x),该函数返回x的平方根

函数
说明
例子
ABS(x)
返回x的绝对值

ABS(10) = 10

ABS(-10) = 10

ACOS(x)
返回x的反余弦

ACOS(1) = 0

ACOS(-1) = 3.1415926

ASIN(x)
返回x的反正弦
这些有兴趣的朋友可以自行验证。
ATAN(x)
返回x的反正切
ATAN2(x)
返回x和y的反正切
BITAND(x,y)
返回对x和y进行位与(AND )操作的结果
COS(x)
返回x的余弦
COSH(x)
返回x的双曲线余弦函数
CEIL(X)
返回大于或等于x的最小整数
EXP(X)
返回e的x次幂,x约等于2.7.18

FLOOR(X)
返回小于或等于x的最大整数

LOG(X,Y)
返回以x为底y的对数

LN(x)
返回x的自然对数

MOD(x,y)
返回x除以y的余数

POWER(x,y)
返回x的y次幂

ROUND(x[,y])
返回对x取整的结果

SIGN(x)
如果x是负数则返回-1,如果是整数,返回1,如果是0,返回0

SIN(X)
返回x的正弦函数

SINH(x)
返回x的双曲线正弦函数

SQRT(x)
返回x的平方根

TAN(x)
返回x的正切函数

1.3 转换函数

    有时可能需要将一个值从一种数据类型转换为另一种数据类型。

ASCIISTR(x)
将x转换为一个ASCII字符串
BIN_TO_NUM(x)
将二进制数字x转换为NUMBER类型
DECODE(x,search,result,default)
将x与search中的值进行比较,如果相等,返回result的值,否则返回default
TO_BINARY_DOUBLE(x)
将x转换为一个BINARY_DOUBLE类型
TO_BINARY_FLOAT(x)
将x转换为一个BINARY_FLOAT类型
TO_BLOB(x)
将x转换为一个二进制大对象(BLOB)类型。
TO_CHAR(x[,format])
将x转换为一个VARCHAR2字符串。可以指定一个可选参数format来说明x的格式
TO_CLOB(x)
将x转换为一个字符大对象(CLOB)类型。
TO_DATE(x[,format])
将x转换为一个DATE类型。
TO_TIMESTAMP(x)
将字符串x转换为一个TIMESTAMP类型

1.4 正则表达式函数

    正则表达式中包含许多元字符。^可以匹配一个字符串的开头:[5-8]可以匹配介于5~8之间的数字;$可以匹配一个字符串的结尾。

    orcle中常用的元字符

元字符
说明
例子

\

说明要匹配的字符是一个特殊字符、常量

\n匹配换行符

\\匹配\

\(匹配(

\)匹配)

^
匹配字符串的开头位置

$
匹配字符串的末尾位置

*
匹配前面的字符0次或多次
ba*rk可以匹配brk,bark,baark
+
匹配前面字符串1此或多次
ba+rk可以匹配bark、baark等
?
匹配前面的字符0次或1次

{n}
匹配一个字符恰好是n次,
hob{2}it可以匹配hobbit
{n,m}
匹配一个字符至少n次,最多m次

.
匹配出null之外的任意单个字符

(pattern)
匹配一个指定的子表达式

x|y
匹配x或者y,

{abc}
匹配abc中的任意一个字符

[a-z]
匹配指定范围内的任意一个字符

[::]
指定一个字符类,可以匹配该类中的任何字符

[:alphanum:]可以匹配字符0-9、A-Z和a-z

[:alpha:]可以匹配字符A-Z和a-z

[:blank:]可以匹配空格和tab键

[:digit:]可以匹配数字0-9

[:graph:]可以匹配非空字符

[:lower:]可以匹配小写字母

[==]
指定等价类

\n
这是对前一次捕获的一个反向引用,其中n是一个正整数

\d
数字字符

\D
非数字字符

\w
字母字符

\W
非字母字符

\s
空白字符

\S
非空白字符

\A
只匹配字符串的开头位置

\Z
只匹配字符串的末尾位置

*?
匹配前面的模式元素0次或多次

+?
匹配前面的模式元素1次或多次

??
匹配前面的模式元素0次或

正则表达式函数
函数
说明
REGEXP_LIKE(x,pattern[,match_option])
从x中搜索pattern参数中定义的正则表达式。可以使用match_option修改默认匹配选项
REGEXP_INSRT(x,pattern[,start[,occurence[,rerturn_option[,match_option]]]])

在x中查找pattern,并返回pattern所在的位置。可以指定一下可选参数:

start:开始查找的位置。默认是1,指x的第一个字符

occurrence 说明应该返回当前第几次出现pattern的位置

return_option 说明应该返回什么整数

match_option 修改默认的匹配设置

REGEXP_REPLACE(x,pattern[,replace_string[,start[,occurrence[,match_option]]])
在x中查找pattern,并将其替换为replace_string。其他选项请参照上一个方法

二、使用聚合函数

函数
说明
AVG(x)
返回x的平均值
COUNT(x)
返回一个包含x的查询的行数
MAX(x)
返回x的最大值
MEDIA(x)
返回x的中间值
MIN(x)
返回x的最小值
STDDEV(x)
返回x的标准差
SUM(x)
返回x的和
VARIANCE(x)
返回x的方差

三、对行进行分组GROUP BY,使用HAVING子句过滤行组。Having放在group不要之后.group by可以不与having一起使用,但是having必须与group by一起使用。

本文出自 “阿酷博客源” 博客,请务必保留此出处http://aku28907.blog.51cto.com/5668513/1787618

© 著作权归作者所有

共有 人打赏支持
kukudeku
粉丝 119
博文 40
码字总数 107227
作品 0
杭州
程序员
Oracle 11g 的新特性 —— 虚拟列

今天我将为大家解释 Oracle 11g 数据库的新特性 —— 虚拟列 介绍 在老的 Oracle 版本,当我们需要使用表达式或者一些计算公式时,我们会创建数据库视图,如果我们需要在这个视图上使用索引,...

红薯 ⋅ 2012/05/07 ⋅ 11

一个使用MyBatis调用Oracle数据库自定义函数的例子

我的电脑操作系统版本为Win7旗舰版(ServicePack1),Oracle版本为Oracle11g 程序使用的jar包有:mybatis-3.2.2.jar、ojdbc14-10.2.0.2.0.jar 本例中使用的配置文件mybatis-config.xml、Per...

北风其凉 ⋅ 2016/03/05 ⋅ 0

索引 技巧

避免在索引列上使用计算和函数. WHERE子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描. 举例: 低效: SELECT … FROM DEPT WHERE SAL * 12 > 25000; 高效: SELECT …...

Reborn-D ⋅ 2016/10/17 ⋅ 0

mysql和oracle的不同

一、日期处理 二、连接字符串在Oracle中用 ,SqlServer中用+,MySQL中用concat('a','b','c') 三、mysql与oracle数据库实现自增列的区别: mysql可以实现自增列,只要在建表时设置auto_incremen...

-wangming- ⋅ 2016/06/06 ⋅ 0

Oracle笔记 目录索引

Oracle笔记 一、oracle的安装、sqlplus的使用 Oracle笔记 二、常用dba命令行 Oracle笔记 三、function 、selectOracle笔记 四、增删改、事务 Oracle笔记 五、创建表、约束、视图、索引、序列...

ibm_hoojo ⋅ 2011/05/03 ⋅ 0

EDB和Oracle在分区剪裁实践上的一点差别

前两天碰到一个问题,在EDB数据库中创建的一张分区表,需要使用分区本地索引和分区剪裁,但查看执行计划发现没能用到分区剪裁的功能。 创建分区表: 创建主表和三个分区的本地索引: 执行以下...

bisal ⋅ 2015/11/28 ⋅ 0

一个使用MyBatis将数据库表中的一列内容放到List的例子

我的电脑操作系统版本为Win7旗舰版(ServicePack1),Oracle版本为Oracle11g 程序使用的jar包有:mybatis-3.2.2.jar、ojdbc14-10.2.0.2.0.jar 本例中使用的配置文件mybatis-config.xml,可以...

北风其凉 ⋅ 2016/03/14 ⋅ 0

有关int 和 Object 转换问题(oracle 10 默认JDK 1.4.2)

前天使用rhino 和js做了一个oracle的function,由于客户使用的是oracle 10,所以只支持jdk1.4.2的,其实很简单的,就是让oracle的函数支持使用javascript编写,实现过程较为简单,就是在传递参...

idoz ⋅ 2013/05/29 ⋅ 0

Oracle 行转列pivot 、列转行unpivot 的Sql语句总结

转自:http://blog.csdn.net/xiaokui_wingfly/article/details/42419207 多行转字符串 这个比较简单,用||或concat函数可以实现 实际上就是拆分字符串的问题,可以使用 substr、instr、regex...

Amui ⋅ 2016/06/29 ⋅ 0

oralce与mysql的区别

有些人说Oracle没有限制,实际上他们说得可能是Oracle不支持LIMIT语法.不过可以rownum虚列来实现,不过会更加麻烦.   2. Oracle不支持偏移(offset)语法. 3. Oracle的复制功能可能比MySQL更加...

wersdffg ⋅ 2015/10/17 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

sbt网络问题解决方案

http://dblab.xmu.edu.cn/blog/maven-network-problem/

狐狸老侠 ⋅ 5分钟前 ⋅ 0

大数据,必须掌握的10项顶级安全技术

我们看到越来越多的数据泄漏事故、勒索软件和其他类型的网络攻击,这使得安全成为一个热门话题。 去年,企业IT面临的威胁仍然处于非常高的水平,每天都会看到媒体报道大量数据泄漏事故和攻击...

p柯西 ⋅ 49分钟前 ⋅ 0

Linux下安装配置Hadoop2.7.6

前提 安装jdk 下载 wget http://mirrors.hust.edu.cn/apache/hadoop/common/hadoop-2.7.6/hadoop-2.7.6.tar.gz 解压 配置 vim /etc/profile # 配置java环境变量 export JAVA_HOME=/opt/jdk1......

晨猫 ⋅ 54分钟前 ⋅ 0

crontab工具介绍

crontab crontab 是一个用于设置周期性被执行的任务工具。 周期性执行的任务列表称为Cron Table crontab(选项)(参数) -e:编辑该用户的计时器设置; -l:列出该用户的计时器设置; -r:删除该...

Linux学习笔记 ⋅ 今天 ⋅ 0

深入Java多线程——Java内存模型深入(2)

5. final域的内存语义 5.1 final域的重排序规则 1.对于final域,编译器和处理器要遵守两个重排序规则: (1)在构造函数内对一个final域的写入,与随后把这个被构造对象的引用赋值给一个引用...

江左煤郎 ⋅ 今天 ⋅ 0

面试-正向代理和反向代理

面试-正向代理和反向代理 Nginx 是一个高性能的反向代理服务器,但同时也支持正向代理方式的配置。

秋日芒草 ⋅ 今天 ⋅ 0

Spring 依赖注入(DI)

1、Setter方法注入: 通过设置方法注入依赖。这种方法既简单又常用。 类中定义set()方法: public class HelloWorldOutput{ HelloWorld helloWorld; public void setHelloWorld...

霍淇滨 ⋅ 昨天 ⋅ 0

马氏距离与欧氏距离

马氏距离 马氏距离也可以定义为两个服从同一分布并且其协方差矩阵为Σ的随机变量之间的差异程度。 如果协方差矩阵为单位矩阵,那么马氏距离就简化为欧氏距离,如果协方差矩阵为对角阵,则其也...

漫步当下 ⋅ 昨天 ⋅ 0

聊聊spring cloud的RequestRateLimiterGatewayFilter

序 本文主要研究一下spring cloud的RequestRateLimiterGatewayFilter GatewayAutoConfiguration @Configuration@ConditionalOnProperty(name = "spring.cloud.gateway.enabled", matchIfMi......

go4it ⋅ 昨天 ⋅ 0

Spring clound 组件

Spring Cloud技术应用从场景上可以分为两大类:润物无声类和独挑大梁类。 润物无声,融合在每个微服务中、依赖其它组件并为其提供服务。 Ribbon,客户端负载均衡,特性有区域亲和、重试机制。...

英雄有梦没死就别停 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部