最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle数据库实用函数

来源:懂视网 责编:小采 时间:2020-11-09 12:33:51
文档

Oracle数据库实用函数

Oracle数据库实用函数:Oracle实用函数 DECODE 语法如下: DECODE(value, if1, then1, if2,then2,if3,then3, . . . else ) Value 代表某个表的任何类 Oracle实用函数 DECODE 语法如下: DECODE(value, if1, then1, if2,then2,if3,th
推荐度:
导读Oracle数据库实用函数:Oracle实用函数 DECODE 语法如下: DECODE(value, if1, then1, if2,then2,if3,then3, . . . else ) Value 代表某个表的任何类 Oracle实用函数 DECODE 语法如下: DECODE(value, if1, then1, if2,then2,if3,th

Oracle实用函数 DECODE 语法如下: DECODE(value, if1, then1, if2,then2,if3,then3, . . . else ) Value 代表某个表的任何类

Oracle实用函数

DECODE

语法如下:  

DECODE(value, if1, then1, if2,then2,if3,then3, . . . else ) Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,Decode 结果就返回else 。  需要注意的是,这里的if、then及else 都可以是函数或计算表达式。

实例

INSTR

返回要查找字符的位置

CASEWHEN

详见

--简单Case函数

CASE sex

WHEN '1' THEN '男'

WHEN '2' THEN '女'

ELSE '其他' END

--Case搜索函数

CASE

WHEN sex = '1' THEN '男'

WHEN sex = '2' THEN '女'

ELSE '其他' END

decode只能做等值的,case when可以做区间的,使用范围来进行条件区分,decode能做到的,case when也能做到;效率方面,个人觉得两者效率差不多;但decode的语法要简单些,但它只能做等值的比较;case when end 能做条件的判断。

SUBSTR

substr() 函数返回字符串的一部分。

语法:substr(string,start,length)

string - 指定的要截取的字符串。

start - 必需,规定在字符串的何处开始。

正数 - 在字符串的指定位置开始

负数 - 在从字符串结尾的指定位置开始

0 - 在字符串中的第一个字符处开始

length - 可选,指定要截取的字符串长度,缺省时返回字符表达式的值结束前的全部字符。

例如:select substr('abcdefg',3,4) from dual;结果是cdef

select substr('abcdefg',-3,4) from dual;结果efg

Oracle正则表达式函数:

regexp_like、regexp_substr、regexp_instr、regexp_replace

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

Linux-6-64下安装Oracle 12C笔记

在CentOS 6.4下安装Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2

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

REPLACE

replace(x,y,z)返回值为将串X中的Y串用Z串替换后的结果字符串。若省略Z参数,,则将串X中为Y串的地方删除

SELECT REPLACE('JACK and JUE','J','BL') "Changes" FROM DUAL;

Changes

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

BLACK and BLUE

例子

有一个列导入的数据应该时‘2011-10-11’的格式,结果导入的数据为‘2011/10/11’格式的,5000多条记录要一条条改基本不可能。 后来想到了replace这个函数,具体用法如下:

update 表1 t set t.列1=replace((select 列1 from 表1 a where a.主键列=t.主键列) ,'/' , '-' ) 解决了我们问题。

replace 函数用法如下:

select"PARENTNAME", "MEMBERNAME", "ALIAS"

'ProductTotal' membername,

from dual)

CONNECT BY

Oracle “CONNECT BY”是层次查询子句,一般用于树状或者层次结果集的查询。其语法是:

[ START WITH condition ]

CONNECTBY [ NOCYCLE ] condition

1. 可用来生成序列

SELECT ROWNUM FROM DUAL CONNECT BY ROWNUM<= 10;

2.可用来实现树状查询

CONNECT BY rownum <= length(p_str))对输入的字符串进行逐个遍历

详见

RPAD

rpad函数从右边对字符串使用指定的字符进行填充   rpad(string,padded_length,[pad_string])  

string 表示:被填充的字符串   

padded_length 表示:字符的长度,是返回的字符串的数量,如果这个数量比原字符串的长度要短,rpad函数将会把字符串截取成从左到右的n个字符;   

pad_string 是个可选参数,这个字符串是要粘贴到string的右边,如果这个参数未写,lpad函数将会在string的右边粘贴空格。   

例如:  

rpad('tech', 7); 将返回'tech '   

rpad('tech', 2); 将返回'te'   

rpad('tech', 8, '0'); 将返回'tech0000'  

rpad('tech on the net', 15, 'z'); 将返回 'tech onthe net'   

rpad('tech on the net', 16, 'z'); 将返回 'tech onthe netz'

TRUNC

TRUNC函数返回以指定元素格式截去一部分的日期值。

1.select trunc(sysdate) from dual 2.select trunc(sysdate, 'mm') from dual 3.select trunc(sysdate,'yy') from dual4.select trunc(sysdate,'dd') from dual5.select trunc(sysdate,'yyyy') from dual6.select trunc(sysdate,'d') from dual7.select trunc(sysdate, 'hh') from dual 8.select trunc(sysdate, 'mi') from dual 9.select trunc(123.458) from dual--123
10.select trunc(123.458,0) from dual--123
11.select trunc(123.458,1) from dual --123.4
12.select trunc(123.458,-1) from dual--120
13.select trunc(123.458,-4) from dual--0
14.select trunc(123.458,4) from dual --123.458
15.select trunc(123) from dual --123
16.select trunc(123,1) from dual--123
17.select trunc(123,-1) from dual--120

一下语句会经常用到,相当于不用创建表而可以插入几条数据

ADD_MONTHS

ADD_MONTHS(d,n)--时间点d再加上n个月

更多详情见请继续阅读下一页的精彩内容:

linux

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Oracle数据库实用函数

Oracle数据库实用函数:Oracle实用函数 DECODE 语法如下: DECODE(value, if1, then1, if2,then2,if3,then3, . . . else ) Value 代表某个表的任何类 Oracle实用函数 DECODE 语法如下: DECODE(value, if1, then1, if2,then2,if3,th
推荐度:
标签: 常用 数据库 函数
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top