阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle使用简单函数

134次阅读
没有评论

共计 3208 个字符,预计需要花费 9 分钟才能阅读完成。

本章将介绍 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 一起使用。

更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2016-06/132146.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计3208字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中