ORACLE 内置函数大全
ORACLE 聚合函数(共7个)
ORACLE 聚合函数(共7个)AVG([distinct|all]x)【功能】统计数据表选中行x列的平均值。
【参数】all表示对所有的值求平均值,distinct只对不同的值求平均值,默认为all 如果有参数distinct或all,需有空格与x(列)隔开。
【参数】x,只能为数值型字段【返回】数字值【示例】环境:create table table3(xm varchar(8),sal number(7,2));insert into table3 values('gao',1111.11);insert into table3 values('gao',1111.11); insert into table3 values('zhu',5555.55);commit;执行统计:select avg(distinct sal),avg(all sal),avg(sal) from table3;结果: 3333.33 2592.59 2592.59SUM([distinct|all]x)【功能】统计数据表选中行x列的合计值。
【参数】all表示对所有的值求合计值,distinct只对不同的值求合计值,默认为all 如果有参数distinct或all,需有空格与x(列)隔开。
【参数】x,只能为数值型字段【返回】数字值【示例】环境:create table table3(xm varchar(8),sal number(7,2));insert into table3 values('gao',1111.11);insert into table3 values('gao',1111.11);insert into table3 values('zhu',5555.55);commit;执行统计:select SUM(distinct sal),SUM(all sal),SUM(sal) from table3;结果: 6666.66 7777.77 7777.77STDDEV([distinct|all]x)【功能】统计数据表选中行x列的标准误差。
oracle数学函数
oracle数学函数Oracle数据库中提供了多种数学函数,用于处理数值数据。
这些函数可以用于执行各种计算,包括取整、四舍五入、求平方根、幂运算、三角函数等等。
以下将介绍一些常用的Oracle数学函数:1.ABS(x)函数:返回给定数值x的绝对值。
如ABS(-5)的结果为54.CEIL(x)函数:返回不小于给定数值x的最小整数。
如CEIL(3.6)的结果为45.FLOOR(x)函数:返回不大于给定数值x的最大整数。
如FLOOR(3.6)的结果为36.MOD(x,y)函数:返回给定数值x除以y的余数。
如MOD(10,3)的结果为17.POWER(x,y)函数:返回给定数值x的y次幂。
如POWER(2,3)的结果为88.SQRT(x)函数:返回给定数值x的平方根。
如SQRT(9)的结果为311.LOG(x,y)函数:返回给定数值x的以y为底的对数。
如LOG(100,10)的结果为212.SIN(x)函数:返回给定角度x的正弦值。
其中角度的单位为弧度。
如SIN(PI/2)的结果为113.COS(x)函数:返回给定角度x的余弦值。
其中角度的单位为弧度。
如COS(PI/3)的结果为0.514.TAN(x)函数:返回给定角度x的正切值。
其中角度的单位为弧度。
如TAN(PI/4)的结果为115.ASIN(x)函数:返回给定数值x的反正弦值(弧度)。
如ASIN(1)的结果为PI/216.ACOS(x)函数:返回给定数值x的反余弦值(弧度)。
如ACOS(0.5)的结果为PI/317.ATAN(x)函数:返回给定数值x的反正切值(弧度)。
如ATAN(1)的结果为PI/418.ATAN2(y,x)函数:返回给定直角坐标系中点(x,y)的极坐标系中点的角度值(弧度)。
如ATAN2(1,1)的结果为PI/4以上只是一些常用的Oracle数学函数,Oracle还提供了更多的数学函数,如指数函数、对数函数、双曲函数等等。
可以根据具体需求选择适合的函数进行数值计算。
oralce函数
oralce函数Oracle是一种关系数据库管理系统,它使用了一种名为Oracle数据库的数据库管理系统。
Oracle是一种强大的工具,提供了许多内置函数,可以用于在数据库中进行各种操作。
以下是一些常用的Oracle函数。
1.聚合函数-AVG:计算指定列的平均值。
-COUNT:计算指定列中非空数据的数量。
-SUM:计算指定列的总和。
-MAX:找到指定列的最大值。
-MIN:找到指定列的最小值。
2.字符串函数-CONCAT:将两个字符串连接成一个字符串。
-LOWER:将字符串转换为小写。
-UPPER:将字符串转换为大写。
-LENGTH:计算字符串的长度。
-SUBSTR:返回一个字符串的子字符串。
3.数值函数-ROUND:将一个数值四舍五入到指定的小数位数。
-CEIL:向上取整,返回不小于指定数值的最小整数。
-FLOOR:向下取整,返回不大于指定数值的最大整数。
-ABS:返回指定数值的绝对值。
-MOD:返回两个数值的余数。
4.日期和时间函数-SYSDATE:返回当前日期和时间。
-ADD_MONTHS:在指定日期上增加指定的月份。
-TRUNC:截断日期或时间到指定的精度。
-MONTHS_BETWEEN:计算两个日期之间的月数差。
-TO_CHAR:将日期转换为指定格式的字符串。
5.条件函数-DECODE:根据条件返回不同的值。
-CASE:根据条件执行不同的操作。
-NVL:如果给定的表达式为NULL,则将其替换为指定的值。
-NULLIF:如果两个表达式的值相等,则返回NULL。
6.分析函数-ROW_NUMBER:为每一行分配一个唯一的数字。
-RANK:为每一行分配一个排名,如果有并列的值,则排名相同。
-DENSE_RANK:为每一行分配一个排名,如果有并列的值,则排名可以重复。
-LEAD:返回指定行后的值。
-LAG:返回指定行前的值。
上述函数只是Oracle提供的一小部分功能,Oracle还提供了许多其他有用的函数。
Oracle带参数的自定义函数
query_sql := 'select count(1) from ' || table_name;
execute immediate query_sql into t_count;
return t_count;
end;
end getRecordCount;
/
(2) 函数调用
set serverout on
Oracle带参数的自定义函数
Oracle带参数的自定义函数
(1) 函数编写
create or replace function getRecordCount(table_name varchar2) return number as
begin
declare t_count number;
query_sql varchar2(200);
end;
/
执行结果:
The record count of table emp is 14
oracle带参数的自定义函数 oracle带参数的自定义函数 (1)函数编写 create or replace function getrecordcount(table_name varchar2) return number as begin declare t_count number; query_sql varchar2(200); begin query_sql := 'select count(1) from ' || table_name; execute immediate query_sql into t_count; return t_count; end; end getrecordcount; / (2)函数调用 set serverout on declare table_name varchar2(50); begin table_name := 'dept'; dbms_output.put_line('the record count of table ' || table_name || ' is ' || getrecordcount(table_name)); end; / 执行结果: the record count of table dept is 4 pl/sql procedure successfully completed. 换个表名试试: declare table_name varchar2(50); begin table_name := 'emp'; dbms_output.put_line('the record count of table ' || table_name || ' is ' || getrecordcount(table_name)); end; / 执行结果: the record count of table emp is 14 下载文档原格式( word原格式 ,共1页)
oracle常用函数使用大全_最新整理
单值函 数在查询 中返回单 个值,可 被应用到 select, where子 句,start with以及 connect by 子句 和having 子句。 (一).数值 型函数 (Number Functions ) 数值型函 数输入数 字型参数 并返回数 值型的值 。多数该 类函数的 返回值支 持38位小 数点,诸 如:COS, COSH, EXP, LN, LOG, SIN, SINH, SQRT, TAN, and TANH 支 持36位小 数点。 ACOS, ASIN, ATAN, and ATAN2支 持30位小
n1<0,则 oracle从 右向左数 确认起始 位置 例如: SELECT SUBSTR( 'What is this',-5,3) FROM DUAL;
n1>c1.len gth则返 回空 例如: SELECT SUBSTR( 'What is this',50,3) FROM DUAL; 然后再请 你猜猜, 如果 n2<1,会 如何返回 值呢
3、 TRUNC(n 1[,n2] 返 回截尾到 n2位小数 的n1的 值,n2缺 省设置为 0,当n2为 缺省设置 时会将n1 截尾为整 数,如果 n2为负 值,就截 尾在小数 点左边相 应的位上 。 例如: SELECT TRUNC(2 3.56),TRU NC(23.56, 1),TRUNC (23.56,-1) FROM DUAL;
例如: SELECT REPLAC E('WWhhh hhaT is tHis w W','W','-') FROM
9、 SOUNDE X(c) 神奇 的函数 啊,该函 数返回字 符串参数 的语音表 示形式, 对于比较 一些读音 相同,但 是拼写不 同的单词 非常有用 。计算语 音的算法 如下:
ORACLE常用函数功能演示
ORACLE常用函数功能演示文档撰写:孟祥新写在前面:ORACLE内置函数,相当于C语言中的库函数,提供了常规数据库编程中所需的绝大多数基本功能,并且通过函数的组合或嵌套使用,可以发挥其强大的功能。
由于这些内置函数都是由ORACLE公司的编程大家所写,而且其执行代码是内嵌在ORACLE数据库系统中的,因此其执行效率极高。
在数据库编程中能广泛使用ORACLE所提供的内置函数,将大大提高程序代码的执行效率。
“站在高人的肩膀上,将使你变得更高”。
演示之前的环境设置:为了在SQL*PLUS中直观地显示函数返回的结果,我将“头”信息先屏蔽掉。
操作如下:一、单行函数1.数值函数(1)三角函数①SIN、ASIN、SINH(正弦、反正弦、双曲正弦)②COS、ACOS、COSH(余弦、反余弦、双曲余弦)③TAN、ATAN、TANH(正切、反正切,双曲正切)(2)幂、方根及对数运算函数①POWER(m, n)(取m的n次幂)②SQRT(n)(取n的平方根)③EXP(n)(取自然对数底e的n次方根)④LN(n)(取n的自然对数)⑤LOG(m, n)(取以m为底n的对数)以上函数功能演示如下:(3)数值处理函数①ABS(n)(取绝对值)②SIGN(n)(符号函数)③CEIL(n)(取不小于n的最小整数)④FLOOR(n)(取不大于n的最大整数)⑤ROUND(n, [m])(按m精度对n进行4舍5入)⑥TRUNC(n, [m])(按m精度对n进行截取)⑦MOD(m, n)(取m除以n的余数)以上函数功能演示如下:2.字符处理函数(1)对字符串的大小写处理的函数①INITCAP(功能:将字符串中每个单词的首字母,变换为大写。
)②UPPER(功能:将字符串中的所有字母,转换为大写。
)③LOWER(功能:将字符串中的所有字母,转换为小写。
)以上函数功能演示如下:(2)对字符串进行处理的函数①CONCAT(字符串连接函数,也可用|| 替代)功能演示如下:②ASCII(取字符的编码)③CHR(将编码转换为对应的字符)以上函数功能演示如下:④LTRIM(去除左侧空格/指定字符)⑤RTRIM(去除右侧空格/指定字符)⑥TRIM(去除两侧的空格/去除指定字符)以上函数去除空格功能演示如下:以上函数去除指定字符功能演示如下:请注意:在用TRIM去除字符串中指定字符(非空格)时的特殊用法。
oracle判断正负的函数
Oracle判断正负的函数1. 引言在计算机编程和数学中,判断一个数的正负是一个基本的操作。
在Oracle数据库中,我们可以使用函数来判断一个数是正数、负数还是零。
本文将详细介绍如何编写一个Oracle函数来完成这个任务。
2. Oracle内置函数Oracle提供了一些内置函数用于数值操作,包括判断正负的函数。
下面是两个常用的函数:2.1. SIGN函数SIGN函数用于判断一个数的正负,并返回对应的符号。
当参数为负数时,函数返回-1;当参数为正数时,函数返回1;当参数为零时,函数返回0。
2.2. ABS函数ABS函数用于返回一个数的绝对值。
无论参数是正数还是负数,函数都会返回一个非负数。
3. 自定义Oracle函数除了使用内置函数外,我们还可以自定义一个Oracle函数来判断一个数的正负。
下面是一个示例函数的定义:CREATE OR REPLACE FUNCTION check_sign(num IN NUMBER)RETURN VARCHAR2ISresult VARCHAR2(10);BEGINIF num > 0 THENresult := 'Positive';ELSIF num < 0 THENresult := 'Negative';ELSEresult := 'Zero';END IF;RETURN result;END;/上述函数接受一个NUMBER类型的参数num,并根据num的值返回对应的字符串。
如果num大于0,则返回”Positive”;如果num小于0,则返回”Negative”;如果num等于0,则返回”Zero”。
4. 使用内置函数判断正负在Oracle中,我们可以使用内置函数SIGN来判断一个数的正负。
下面是一个使用SIGN函数的示例:SELECT SIGN(10) AS resultFROM DUAL;上述语句将返回1,因为10是一个正数。
Oracle内置函数(数值型).docx
6.1数值型函数绝对值、取余、判断数值正负函数SELECT ABS(100)z ABS(-100)z ABS(11001) FROM DUAL;第三个ABS ( TOO,)参数类型虽然不是数值型但是可以隐式转换成数值类型,也可以用ABSocreate table SYS.DUAL(DUMMY VARCHAR2(1SELECT MOD(5, 2),MOD(8/3, 5),MOD(-10, 6),MOD(1, 0) FROM DUAL; 参数是任意类型或者可以隐式转换成数值的类型MOD(5, 2)MOD(8/3, 5)MOD(-10, 6)MOD(1, 0)±Jj12JK666666666667-41注意:MOD(x, 0)X;SELECT SIGNC^1 ) ,SIGN(,-9, ) , SIGN (0.00) ,SIGN(-2*,9, ) FROM DUAL;SIG叫9) | SIGNC-9') SIGN(O.OO)」SIGN(-2*'9')► 1 1| T| 0| -1|三角函数COS(n)函数。
□ACOS(n):返回n的反余弦值。
□COSH(n):返回n的双曲余弦值。
□SIN(n):返冋n的正弦值。
□SINH(n):返回n的双曲正弦值。
□ASIN(n);返回n的反正弦值。
□TAN(n):返回n的正切值。
□TANH(n):返回n的双曲正切值。
□ATAN(n):返回n的反正切值。
select sin (兀/6) a from dual; ili®在ormcle 中n 标示符无效select sin (3•141592653/6) a from dual;A l►10.499999999914871返I川以指定数值为准整数的苗数CETL (N)1) CEIL(n)函数。
其返回结果是大干等于输入参数的最小整数。
该输入参数要. 数值类型,或可以隐式地转换成数值的类型,可U是非整数。
Oracleform_builder内置函数说明.
abort_query;停止查询的执行add_group_column(record group id或name,group column添加一个列至U—个记录组,Record group idn ame,colu mn type,colu mn width;add_group_row(record group id或name,row number;添加一个行至U—个记录组,record group id是oracle赋予这个组的唯一的名称,row number指定了这个行在组中位置.add」ist_eleme nt(list n ame or list id,list index,list lable,list value;添加一项到下拉列表框,list name是list 的名字,list index 是添加到列表框的索引,list label指定了放入列表中的数值串,list value包含了列表标识所对应的数据库的数值.add_parameter(list或name,parameter,parameter type,valu添加一个参数至U—个参数列表,参数列表是一个变量列表,这些变量将被伟给其他对象,list或name指定了这个列表的标识,parameter type参数类型包含两种可用数值:text_type是一串字符;data_paramete是一个指定已在form中定义的记录组的串.value是传给被调模块的实际数值.application_parameter促使oracle 显示Enter parameter values对话框。
关联了当前菜单form的参数按其数值被显示。
backgrou nd_me nu (1...10从背景菜单中显示一个菜单项bell;促使终址产生一个鸣叫(要有音响或耳机才能听以哦!block_menu;显示一个数值的列表,它包括有效块的名字和它们的序列号break;停止form的执行,显示调试器.注:只能在调试模式时call」nput;接受并执行功能键输入;checkbox_checked( name返回一个真或假的值表示检查框的状态check_record_uniquenes被on_check_unique触发器调用时,为检查主关键字的唯一性而被始化form过程.clear_block人当前的块中清除记录.clear_eol;从光标开始到些行结束清除文本项的值。
Oracle内置函数大全
Oracl e SQL 内置函数大全(一)整理时间[2005-10-14] 阅读次数[6224]导读:Oracle SQL 内置函数大全(一)Oracle SQL 内置函数大全(二)Oracle SQL 内置函数大全(三)________________________________________文字大小:【大】【中】【小】SQL中的单记录函数1.ASCII返回与指定的字符对应的十进制数;SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;A a ZERO SPACE--------- --------- --------- ---------65 97 48 322. 2.CHR给出整数,返回对应的字符;SQL> select chr(54740) zhao,chr(65) chr65 from dual;ZH C-- -赵A3. 3.CONCAT连接两个字符串;SQL> select concat('010-','88888888')||'转23' 高乾竞电话from dual; 高乾竞电话----------------010-********转234. 4.INITCAP返回字符串并将字符串的第一个字母变为大写;SQL> select initcap('smith') upp from dual;UPP-----Smith5. 5.INSTR(C1,C2,I,J)在一个字符串中搜索指定的字符,返回发现指定的字符的位置;C1 被搜索的字符串C2 希望搜索的字符串I 搜索的开始位置,默认为1J 出现的位置,默认为1(第一次?)SQL> select instr('oracle traning','ra',1,2) instring from dual;INSTRING---------96. 6.LENGTH返回字符串的长度;SQL> selectname,length(name),addr,length(addr),sal,length(to_char(sal))from .nchar_tst; NAME LENGTH(NAME) ADDR LENGTH(ADDR) SALLENGTH(TO_CHAR(SAL))------ ------------ ---------------- ------------ --------- --------------------高乾竞 3 北京市海锭区 6 9999.99 7。
oracle数字函数(共22个)
oracle数字函数dual是一个"伪表",可以用来测试函数和表达式。
1、Round:四舍五入Round(45.926,2)→45.93Round(45.923,0)保留整数位,结果是46。
Round(45.923,-1)取整数位的第二位。
就是取十位,结果是50。
Round(45.923,-2)取整数位的第三位。
就是取百位,结果为0。
2、Trunc:数字截断Trunc(45.926,2)→45.92语法: TRUNC(x[,y])功能: 计算截尾到y位小数的x值. y缺省为0,结果变为一个整数值.如果y是一个负数,那么就截尾到小数点左边对应的位上.说明:该函数可以指定截取的位数,当不指定截取位时,它只截取小数占左边的数字。
3、Mod:求余语法: MOD(x,y)功能: 返回x除以y的余数.如果y是0,则返回xMod(1600,300)→1004、ABS语法: ABS(x)功能: 得到x的绝对值.SQL> select abs(1) a,abs(0) b,abs(-1) c,abs(-0.1) d from dualA B C D---------- ---------- ---------- ----------1 0 1 .15、CEIL语法: CEIL(x)功能: 计算大于或等于x的最小整数值.SQL> select ceil(0.3) a,ceil(0.5) b,ceil(0.8) c,ceil(0) d from dualA B C D---------- ---------- ---------- ----------1 1 1 06、FLOOR语法: FLOOR(x)功能: 返回小于等于x的最大整数值.SQL> select floor(0.3) a,floor(0.5) b,floor(0.8) c,floor(0) d from dualA B C D---------- ---------- ---------- ------------------0 0 0 07、ACOS语法: ACOS(x)功能: 返回x的反余弦值. x应该从0到1之间的数,结果在0到pi之间,以弧度为单位.SQL> select cos(0.1667) a,acos(0.5) y,cosh(0.5) z from dualA Y Z---------- ---------- -------------------.986137701 1.04719755 1.127625978、ASIN语法: ASIN(x)功能: 计算x的反正弦值. X的范围应该是-1到1之间,返回的结果在-pi/2到pi/2之间,以弧度为单位. SQL> select sin(0.1667) x,asin(0.5) y,sinh(0.5) z from dualX Y Z---------- ---------- ------------------------.165929004 .523598776 .5210953059、ATAN语法: ATAN(x)功能: 计算x的反正切值.返回值在-pi/2到pi/2之间,单位是弧度.SQL> select tan(0.1667) x ,atan(0.5) y,atan2(1,2) z from dualX Y Z---------- ---------- --------------------.168261495 .463647609 .46364760910、ATAN2语法: ATAN2(x,y)功能: 计算x和y的反正切值.结果在负的pi/2到正的pi/2之间,单位是弧度.atan2(x,y)函数表示,返回x/y的反正切等价于atan(x/y)。
oracle内置取最大最小函数:greatest和least
oracle 内置取最大最小函数:greatest 和leastoracle 中取最大值最小值一般想到的就是组函数max 和min ,这也是我的第一想法,但是别忘了,max 和min 是用来取某个字段的最大最小值,并不是说如果你有几个数,然后你直接从它们中取出最大或者最小,由于我不知道greatest 和least 这两个函数,最后我实现的是通过case 去比较的,如果A 大于B 就取A ,否则取B ,现在就可以直接用greatest(A, B)来实现了。
1、coalescue返回表达式列表中第一个非空的值,列表必须都是相同类型,也可以是一个表的同一行、不同列的值进行比较。
1 2 3 4 5 6 7 8 9 10 11 SELECT coalesce(1,NULL,2)FROM dual; -- 返回1SELECT coalesce(NULL,2,1)FROM dual; -- 返回2SELECT coalesce(t.empno,t.mgr)FROM scott.emp t; -- 效果类似 NVL( t.empno, t.mgr )2、greatest返回表达式列表中最大值,列表必须是相同类型,也可以是一个表的同一行、不同列的值进行比较。
当列表中有一个值为null ,那么就返回null ,这个地方需要注意,如果需要当值为null 的时候,可以考虑用nvl 转为0来进行比较。
1 2 3 4 5 6 7 8 9 10 SELECT greatest(1,3,2) FROM dual; -- 返回3SELECT greatest('A','B','C') FROM dual; -- 返回CSELECT greatest(NULL,'B',11 12 13 14 15 'C')FROM dual; -- 返回nullSELECT greatest(t.empno,t.mgr)FROM scott.emp t; -- 返回empno 和mgr 较大值3、least返回表达式列表中最小值,列表必须是相同类型,也可以是一个表的同一行、不同列的值进行比较。
oracle数学函数
oracle数学函数Oracle数学函数是Oracle数据库中提供的一组函数,用于进行数学运算和处理数值数据。
这些函数可以用于计算、转换和处理数值,使得数据处理更加灵活和高效。
本文将介绍几个常用的Oracle数学函数,并详细说明其用法和功能。
1. ROUND函数ROUND函数用于对数值进行四舍五入。
它接受两个参数,第一个参数是要进行四舍五入的数值,第二个参数是要保留的小数位数。
例如,ROUND(3.14159, 2)将返回3.14,表示将3.14159四舍五入到小数点后两位。
2. TRUNC函数TRUNC函数用于截断数值,即将数值的小数部分截断掉。
它接受两个参数,第一个参数是要进行截断的数值,第二个参数是要保留的小数位数。
例如,TRUNC(3.14159, 2)将返回3.14,表示将3.14159截断到小数点后两位。
3. MOD函数MOD函数用于计算两个数的余数。
它接受两个参数,第一个参数是被除数,第二个参数是除数。
例如,MOD(10, 3)将返回1,表示10除以3的余数为1。
4. POWER函数POWER函数用于计算一个数的幂。
它接受两个参数,第一个参数是底数,第二个参数是指数。
例如,POWER(2, 3)将返回8,表示计算2的3次幂。
5. SQRT函数SQRT函数用于计算一个数的平方根。
它接受一个参数,即要计算平方根的数值。
例如,SQRT(9)将返回3,表示计算9的平方根。
6. ABS函数ABS函数用于计算一个数的绝对值。
它接受一个参数,即要计算绝对值的数值。
例如,ABS(-5)将返回5,表示计算-5的绝对值。
7. EXP函数EXP函数用于计算以自然对数为底的指数幂。
它接受一个参数,即要计算指数幂的数值。
例如,EXP(1)将返回2.71828,表示计算e 的1次幂。
8. LOG函数LOG函数用于计算一个数的自然对数。
它接受一个参数,即要计算自然对数的数值。
例如,LOG(10)将返回2.30259,表示计算以e 为底的对数。
oracle数学函数
oracle数学函数Oracle数据库提供了许多用于数学计算和数值操作的函数。
本文将介绍Oracle中的一些常用数学函数,包括四舍五入、取绝对值、取余数、求平方根、指数和对数等。
一、四舍五入函数1.ROUNDROUND函数用于四舍五入到指定的位数。
以下是ROUND函数的一些常见用法:ROUND(number):将number四舍五入到最近的整数。
ROUND(number, decimal_places):将number四舍五入到指定的小数位数。
2.TRUNCTRUNC函数用于截断小数部分并保留整数部分。
以下是TRUNC函数的一些常见用法:TRUNC(number):将number截断到最近的整数。
TRUNC(number, decimal_places):将number截断到指定的小数位数。
二、取绝对值函数1.ABSABS函数用于取一个数的绝对值。
ABS(number):返回number的绝对值。
三、取余数函数1.MODMOD函数用于取两个数的余数。
MOD(dividend, divisor):返回dividend除以divisor的余数。
四、求平方根函数1.SQRTSQRT函数用于计算一个数的平方根。
SQRT(number):返回number的平方根。
五、指数和对数函数1.EXPEXP函数用于计算指定数的指数值。
EXP(number):返回e的number次幂,其中e是自然对数的底数。
2.LNLN函数用于计算指定数的自然对数。
LN(number):返回number的自然对数。
3.POWERPOWER函数用于计算一个数的指定次幂。
POWER(base, exponent):返回base的exponent次幂。
以上就是Oracle中一些常用的数学函数。
这些函数可以帮助开发者进行数学计算和数值操作,提高数据处理的灵活性和准确性。
使用合适的数学函数可以减少开发工作量,增加程序的效率和可读性。
Oracle基础函数汇总
7
语法:lead(lag) (expression[,offsrt[,default])
8
over ([query partition clause] order by clause)
9
10
--累加合计
11
SUM(字段) over(PARTITION BY 字段 ORDER BY 字段 rows 10000000 preceding) AS
3
4 --avg 函数名
5 --(sal)是分析函数的参数,每个函数有0~3个参数,参数可以是表达式
6 --over 是一个关键字,用于标识分析函数
7 --partition by deptno 是可选的分区子句
8
9
10 --等级函数,排序
11 select t.c_store_id,sum(t.tot_qty),
9 --mod
--取余数
10 select mod(20,3)from dual; --2
11
12
13 --常用日期函数
14 /*--运算规律
15
日期 + 数值=日期
16
日期-数值=日期
17
日期-日期=数值(天数)
18 */
19 select sysdate,sysdate+2,sysdate-3,sysdate-
"字段名称"
12
---
13
with order_i as --临时表定义
14
1 --对账单预计算程序
2 CREATE OR REPLACE PROCEDURE rp_cusrecvcheck_generate(p_pi_id NUMBER) AS
oracle加减乘除法函数
oracle加减乘除法函数
Oracle是一种强大的数据库管理系统,它提供了许多内置函数来处理数据。
其中包括加减乘除法函数。
加法函数:Oracle中的加法函数是“+”,它可以用于两个数字之间的相加操作。
例如,要将数字1和数字2相加,可以使用以下语句:
SELECT 1 + 2 FROM dual;
这将返回结果3。
减法函数:Oracle中的减法函数是“-”,它可以用于两个数字之间的相减操作。
例如,要将数字5从数字10中减去,可以使用以下语句:
SELECT 10 - 5 FROM dual;
这将返回结果5。
乘法函数:Oracle中的乘法函数是“*”,它可以用于两个数字之间的相乘操作。
例如,要将数字3和数字4相乘,可以使用以下语句:
SELECT 3 * 4 FROM dual;
这将返回结果12。
除法函数:Oracle中的除法函数是“/”,它可以用于两个数字之间的相除操作。
例如,要将数字10除以数字2,可以使用以下语句:
SELECT 10 / 2 FROM dual;
这将返回结果5。
需要注意的是,在进行除法操作时需要注意被除数不能为0,否则会出现错误。
此外,在进行浮点数运算时还需要考虑精度问题。
总结来说,Oracle提供了四种基本运算符号来处理数据:加号、减号、乘号和除号。
这些运算符号可以用于数字之间的相加、相减、相乘和
相除操作。
在使用这些函数时,需要注意数据类型和精度问题,以确
保计算结果正确。
Oracle函数手册
1. 单行函数1.1 字符函数LOWER 使字符串小写;select LOWER('HeLp') from dual --->helpUPPER 使字符串大写;select UPPER('HeLp') from dual --->HELPINITCAP 使字符串的第一个字母大写,其它为小写select INITCAP('hELp') from dual --->HelpLENGTH 返回表达式中的字符串长度select LENGTH('hELP') from dual ---->4CONCAT 将值连接到一起(,对于此函数,只能使用2个参数)select CONCAT('Hello', 'World') from dual --->HelloWorldSUBSTR 抽取确定长度的字符串select SUBSTR('HelloWorld',1,5) from dual ---->HelloINSTR 查找指定字符的数字位置select INSTR('HelloWorld', 'W') from dual --->6LPAD 按右对齐填充字符串select LPAD(salary,10,'*') from dual --->*****24000RPAD 按左对齐填充字符串select RPAD(salary, 10, '*') from dual --->24000*****TRIM(leading|trailing|both,trim_character FROM trim_source) 从字符串中截去头部或者尾部的字符(或者头尾都截掉)(如果trim_character或trim_source是一个字符型文字值,则必须将它包含在单引号之内。
oracle中乘法函数
oracle中乘法函数
Oracle中的乘法函数指的是数值类型的相乘操作,主要用于数值计算
和统计分析中。
Oracle中有多个不同的数值类型,包括整数、小数和大数等,每种类
型的乘法函数也有所不同。
下面是几种常用的Oracle乘法函数:
1. * 运算符:这是最常用的乘法函数,用于对两个数值进行相乘运算。
例如,SELECT 2 * 3 FROM DUAL; 将返回6。
2. MULTIPLY 函数:这是一个较为高级的乘法函数,用于在SQL语句中计算两个数值相乘的结果。
例如,SELECT MULTIPLY(2, 3) FROM DUAL; 将返回6。
3. PRODUCT 函数:这是Oracle中的内建函数之一,用于计算多个数值的积。
例如,SELECT PRODUCT(2, 3, 4) FROM DUAL; 将返回24。
4. POWER 函数:这是一个比较特殊的乘法函数,用于计算一个数值
的偏移量(指数)次幂。
例如,SELECT POWER(2, 3) FROM DUAL; 将返回8。
需要注意的是,Oracle的乘法函数只能用于数值计算,不能用于字符串拼接。
如果要进行字符串拼接操作,应该使用Oracle中的字符串连接函数CONCAT。
另外,Oracle中的乘法函数还可以与其他数学函数(如加减乘除、取模运算等)结合使用,实现更加复杂的数学计算。
总的来说,Oracle中的乘法函数是进行数值计算和统计分析的基本工具之一,应用广泛。
通过熟练掌握乘法函数的使用方法,可以在SQL 语句中轻松实现各种数学计算、查询和分析。
oracle的数组函数
oracle的数组函数
在Oracle数据库中,有许多用于处理和操作数组的函数。
以下是一些常见的Oracle 数组函数:
1. ARRAY:该函数用于将单个元素或多个元素组合成一个数组。
示例:SELECT ARRAY(1, 2, 3) FROM dual;--返回[1, 2, 3]
2. CARDINALITY:该函数用于返回数组的大小(即元素的数量)。
示例:SELECT CARDINALITY([1, 2, 3]) FROM dual;--返回3
3. MULTISET:该函数用于创建一个集合(multi-set),其中包含数组的所有元素。
它可以用于去重和计算集合的交、并、差等操作。
示例:SELECT MULTISET(1, 2, 2, 3) FROM dual;--返回[1, 2, 2, 3]
4. MEMBER OF:该运算符用于检查一个元素是否属于数组。
如果元素存在于数组中,则返回TRUE;否则返回FALSE。
示例:SELECT 2 MEMBER OF [1, 2, 3] FROM dual;--返回TRUE
5. TREAT:该函数用于将一个表达式视为指定的类型进行处理。
在处理数组时,TREAT函数可以用于访问数组特定位置的元素。
示例:SELECT TREAT([1, 2, 3] AS SYS.ODCINUMBERLIST)(2) FROM dual;--返回2
这些是一些常见的Oracle数组函数,可以帮助您处理和操作数组数据。
请注意,数组在Oracle中通常使用嵌套表(nested table)或V ARRAY(variable-size array)数据类型来表示。
1。
oracle中常用的函数
oracle中常用的函数Oracle是一种流行的关系型数据库管理系统,它提供了许多强大的函数来处理数据。
以下是Oracle中常用的函数:1. 字符串函数Oracle提供了许多字符串函数来处理文本数据。
其中一些常用的函数包括:- SUBSTR:用于提取字符串的一部分。
- INSTR:用于查找字符串中的子字符串。
- CONCAT:用于连接两个或多个字符串。
- REPLACE:用于替换字符串中的子字符串。
- UPPER和LOWER:用于将字符串转换为大写或小写。
2. 数值函数Oracle还提供了许多数值函数来处理数字数据。
其中一些常用的函数包括:- ROUND:用于将数字四舍五入到指定的小数位数。
- TRUNC:用于截断数字到指定的小数位数。
- MOD:用于计算两个数字的余数。
- ABS:用于计算数字的绝对值。
- SIGN:用于确定数字的符号。
3. 日期函数Oracle还提供了许多日期函数来处理日期和时间数据。
其中一些常用的函数包括:- SYSDATE:用于返回当前日期和时间。
- ADD_MONTHS:用于将指定的月数添加到日期中。
- MONTHS_BETWEEN:用于计算两个日期之间的月数。
- EXTRACT:用于提取日期中的特定部分,如年、月、日、小时、分钟等。
- TO_CHAR和TO_DATE:用于将日期和时间数据转换为字符串或从字符串转换为日期和时间数据。
4. 聚合函数Oracle还提供了许多聚合函数来计算数据的总和、平均值、最大值、最小值等。
其中一些常用的函数包括:- SUM:用于计算数值列的总和。
- AVG:用于计算数值列的平均值。
- MAX和MIN:用于查找数值列中的最大值和最小值。
- COUNT:用于计算行数或非空值的数量。
总结Oracle提供了许多强大的函数来处理数据。
这些函数可以帮助开发人员更轻松地处理和分析数据,从而提高应用程序的性能和可靠性。
熟练掌握这些函数可以使开发人员更加高效地编写SQL查询和存储过程。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
SQL中的单记录函数1.ASCII返回与指定的字符对应的十进制数;SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;A A ZERO SPACE--------- --------- --------- ---------65 97 48 322.CHR给出整数,返回对应的字符;SQL> select chr(54740) zhao,chr(65) chr65 from dual;ZH C-- -赵 A3.CONCAT连接两个字符串;SQL> select concat('010-','')||'转23' 高乾竞电话from dual;高乾竞电话----------------010-转234.INITCAP返回字符串并将字符串的第一个字母变为大写;SQL> select initcap('smith') upp from dual;UPP-----Smith5.INSTR(C1,C2,I,J)在一个字符串中搜索指定的字符,返回发现指定的字符的位置;C1 被搜索的字符串C2 希望搜索的字符串I 搜索的开始位置,默认为1J 出现的位置,默认为1SQL> select instr('oracle traning','ra',1,2) instring from dual;INSTRING---------96.LENGTH返回字符串的长度;SQL> select name,length(name),addr,length(addr),sal,length(to_char(sal)) from gao.nchar_tst; NAME LENGTH(NAME) ADDR LENGTH(ADDR) SALLENGTH(TO_CHAR(SAL))------ ------------ ---------------- ------------ --------- --------------------高乾竞 3 北京市海淀区 6 9999.99 7 7.LOWER返回字符串,并将所有的字符小写SQL> select lower('AaBbCcDd')AaBbCcDd from dual;AABBCCDD--------aabbccdd8.UPPER返回字符串,并将所有的字符大写SQL> select upper('AaBbCcDd') upper from dual;UPPER--------AABBCCDD9.RPAD和LPAD(粘贴字符)RPAD 在列的右边粘贴字符LPAD 在列的左边粘贴字符SQL> select lpad(rpad('gao',10,'*'),17,'*')from dual;LPAD(RPAD('GAO',1-----------------*******gao*******不够字符则用*来填满10.LTRIM和RTRIMLTRIM 删除左边出现的字符串RTRIM 删除右边出现的字符串SQL> select ltrim(rtrim(' gao qian jing ',' '),' ') from dual;LTRIM(RTRIM('-------------gao qian jing11.SUBSTR(string,start,count)取子字符串,从start开始,取count个SQL> select substr('',3,8) from dual;SUBSTR('--------12.REPLACE('string','s1','s2')string 希望被替换的字符或变量s1 被替换的字符串s2 要替换的字符串SQL> select replace('he love you','he','i') from dual;REPLACE('H----------i love you13.SOUNDEX返回一个与给定的字符串读音相同的字符串SQL> create table table1(xm varchar(8));SQL> insert into table1 values('weather');SQL> insert into table1 values('wether');SQL> insert into table1 values('gao');SQL> select xm from table1 where soundex(xm)=soundex('weather'); XM--------weatherwether14.TRIM('s' from 'string')LEADING 剪掉前面的字符TRAILING 剪掉后面的字符如果不指定,默认为空格符15.ABS返回指定值的绝对值SQL> select abs(100),abs(-100) from dual;ABS(100) ABS(-100)--------- ---------100 10016.ACOS给出反余弦的值SQL> select acos(-1) from dual;ACOS(-1)---------3.17.ASIN给出反正弦的值SQL> select asin(0.5) from dual;ASIN(0.5)---------.18.ATAN返回一个数字的反正切值SQL> select atan(1) from dual;ATAN(1)---------.19.CEIL返回大于或等于给出数字的最小整数SQL> select ceil(3.) from dual;CEIL(3.)---------------420.COS返回一个给定数字的余弦SQL> select cos(-3.) from dual;COS(-3.)----------------121.COSH返回一个数字反余弦值SQL> select cosh(20) from dual; COSH(20)---------22.EXP返回一个数字e的n次方根SQL> select exp(2),exp(1) from dual; EXP(2) EXP(1)--------- ---------7. 2.23.FLOOR对给定的数字取整数SQL> select floor(2345.67) from dual; FLOOR(2345.67)--------------234524.LN返回一个数字的对数值SQL> select ln(1),ln(2),ln(2.) from dual;LN(1) LN(2) LN(2.)--------- --------- -------------0 . .25.LOG(n1,n2)返回一个以n1为底n2的对数SQL> select log(2,1),log(2,4) from dual;LOG(2,1) LOG(2,4)--------- ---------0 226.MOD(n1,n2)返回一个n1除以n2的余数SQL> select mod(10,3),mod(3,3),mod(2,3) from dual;MOD(10,3) MOD(3,3) MOD(2,3)--------- --------- ---------1 0 226.Sign(N)返回一个数的正负,正返回1零返回0负返回-127.POWER返回n1的n2次方根SQL> select power(2,10),power(3,3) from dual;POWER(2,10) POWER(3,3)----------- ----------1024 2728.ROUND和TRUNC按照指定的精度进行舍入SQL> select round(55.5),round(-55.4),trunc(55.5),trunc(-55.5) from dual; ROUND(55.5) ROUND(-55.4) TRUNC(55.5) TRUNC(-55.5)----------- ------------ ----------- ------------56 -55 55 -5529.SIGN取数字n的符号,大于0返回1,小于0返回-1,等于0返回0SQL> select sign(123),sign(-100),sign(0) from dual;SIGN(123) SIGN(-100) SIGN(0)--------- ---------- ---------1 -1 030.SIN返回一个数字的正弦值SQL> select sin(1.57079) from dual;SIN(1.57079)------------131.SIGH返回双曲正弦的值SQL> select sin(20),sinh(20) from dual;SIN(20) SINH(20)--------- ---------.32.SQRT返回数字n的根SQL> select sqrt(64),sqrt(10) from dual;SQRT(64) SQRT(10)--------- ---------8 3.33.TAN返回数字的正切值SQL> select tan(20),tan(10) from dual;TAN(20) TAN(10)--------- ---------2. .34.TANH返回数字n的双曲正切值SQL> select tanh(20),tan(20) from dual;TANH(20) TAN(20)--------- ---------1 2.35.TRUNC按照指定的精度截取一个数SQL> select trunc(124.1666,-2) trunc1,trunc(124.16666,2) from dual;TRUNC1 TRUNC(124.16666,2)--------- ------------------100 124.1636.ADD_MONTHS增加或减去月份SQL> select to_char(add_months(to_date('','yyyymm'),2),'yyyymm') from dual;------SQL> select to_char(add_months(to_date('','yyyymm'),-2),'yyyymm') from dual;TO_CHA------ST_DAY返回日期的最后一天SQL> select to_char(sysdate,'yyyy.mm.dd'),to_char((sysdate)+1,'yyyy.mm.dd') from dual; TO_CHAR(SY TO_CHAR((S---------- ----------2004.05.09 2004.05.10SQL> select last_day(sysdate) from dual;LAST_DAY(S----------31-5月-0438.MONTHS_BETWEEN(date2,date1)给出date2-date1的月份SQL> select months_between('19-12月-1999','19-3月-1999') mon_between from dual; MON_BETWEEN-----------9SQL>selectmonths_between(to_date('2000.05.20','yyyy.mm.dd'),to_date('2005.05.20','yyyy.m m.dd')) mon_betw from dual;MON_BETW----------6039.NEW_TIME(date,'this','that')给出在this时区=other时区的日期和时间SQL> select to_char(sysdate,'yyyy.mm.dd hh24:mi:ss') bj_time,to_char(new_time2 (sysdate,'PDT','GMT'),'yyyy.mm.dd hh24:mi:ss') los_angles from dual;BJ_TIME LOS_ANGLES------------------- -------------------2004.05.09 11:05:32 2004.05.09 18:05:3240.NEXT_DAY(date,'day')给出日期date和星期x之后计算下一个星期的日期SQL> select next_day('18-5月-2001','星期五') next_day from dual;NEXT_DAY----------41.SYSDATE用来得到系统的当前日期SQL> select to_char(sysdate,'dd-mm-yyyy day') from dual;TO_CHAR(SYSDATE,'-----------------09-05-2004 星期日trunc(date,fmt)按照给出的要求将日期截断,如果fmt='mi'表示保留分,截断秒SQL> select to_char(trunc(sysdate,'hh'),'yyyy.mm.dd hh24:mi:ss') hh,2 to_char(trunc(sysdate,'mi'),'yyyy.mm.dd hh24:mi:ss') hhmm from dual; HH HHMM------------------- -------------------2004.05.09 11:00:00 2004.05.09 11:17:0042.CHARTOROWID将字符数据类型转换为ROWID类型SQL> select rowid,rowidtochar(rowid),ename from scott.emp;ROWID ROWIDTOCHAR(ROWID) ENAME------------------ ------------------ ----------AAAAfKAACAAAAEqAAA AAAAfKAACAAAAEqAAA SMITH AAAAfKAACAAAAEqAAB AAAAfKAACAAAAEqAAB ALLEN AAAAfKAACAAAAEqAAC AAAAfKAACAAAAEqAAC WARD AAAAfKAACAAAAEqAAD AAAAfKAACAAAAEqAAD JONES43.CONVERT(c,dset,sset)将源字符串sset从一个语言字符集转换到另一个目的dset字符集SQL> select convert('strutz','we8hp','f7dec') "conversion" from dual; conver------strutz44.HEXTORAW将一个十六进制构成的字符串转换为二进制45.RAWTOHEXT将一个二进制构成的字符串转换为十六进制46.ROWIDTOCHAR将ROWID数据类型转换为字符类型47.TO_CHAR(date,'format')SQL> select to_char(sysdate,'yyyy/mm/dd hh24:mi:ss') from dual;TO_CHAR(SYSDATE,'YY-------------------2004/05/09 21:14:4148.TO_DATE(string,'format')将字符串转化为ORACLE中的一个日期49.TO_MULTI_BYTE将字符串中的单字节字符转化为多字节字符SQL> select to_multi_byte('高') from dual;TO--高50.TO_NUMBER将给出的字符转换为数字SQL> select to_number('1999') year from dual;YEAR---------199951.BFILENAME(dir,file)指定一个外部二进制文件SQL>insert into file_tb1 values(bfilename('lob_dir1','image1.gif'));52.CONVERT('x','desc','source')将x字段或变量的源source转换为descSQL> select sid,serial#,username,decode(command,2 0,'none',3 2,'insert',4 3,5 'select',6 6,'update',7 7,'delete',8 8,'drop',9 'other') cmd from v$session where type!='background';SID SERIAL# USERNAME CMD--------- --------- ------------------------------ ------1 1 none2 1 none3 1 none4 1 none5 1 none6 1 none7 1275 none8 1275 none9 20 GAO select10 40 GAO none53.DUMP(s,fmt,start,length)DUMP函数以fmt指定的内部数字格式返回一个VARCHAR2类型的值SQL> col global_name for a30SQL> col dump_string for a50SQL> set lin 200SQL> select global_name,dump(global_name,1017,8,5) dump_string from global_name; GLOBAL_NAME DUMP_STRING------------------------------ --------------------------------------------------ORACLE.WORLD Typ=1 Len=12 CharacterSet=ZHS16GBK: W,O,R,L,D54.EMPTY_BLOB()和EMPTY_CLOB()这两个函数都是用来对大数据类型字段进行初始化操作的函数55.GREATEST返回一组表达式中的最大值,即比较字符的编码大小.SQL> select greatest('AA','AB','AC') from dual;GR--ACSQL> select greatest('啊','安','天') from dual;GR--天56.LEAST返回一组表达式中的最小值SQL> select least('啊','安','天') from dual;LE--啊57.UID返回标识当前用户的唯一整数SQL> show userUSER 为"GAO"SQL> select username,user_id from dba_users where user_id=uid;USERNAME USER_ID------------------------------ ---------GAO 25ER返回当前用户的名字SQL> select user from dual;USER------------------------------GAOEREVN返回当前用户环境的信息,opt可以是:ENTRYID,SESSIONID,TERMINAL,ISDBA,LABLE,LANGUAGE,CLIENT_INFO,LANG,VSIZE ISDBA 查看当前用户是否是DBA如果是则返回trueSQL> select userenv('isdba') from dual;USEREN------FALSESQL> select userenv('isdba') from dual;USEREN------TRUESESSION返回会话标志SQL> select userenv('sessionid') from dual;USERENV('SESSIONID')--------------------152ENTRYID返回会话人口标志SQL> select userenv('entryid') from dual;USERENV('ENTRYID')------------------INSTANCE返回当前INSTANCE的标志SQL> select userenv('instance') from dual;USERENV('INSTANCE')-------------------1LANGUAGE返回当前环境变量SQL> select userenv('language') from dual;USERENV('LANGUAGE')----------------------------------------------------SIMPLIFIED CHINESE_CHINA.ZHS16GBKLANG返回当前环境的语言的缩写SQL> select userenv('lang') from dual;USERENV('LANG')----------------------------------------------------ZHSTERMINAL返回用户的终端或机器的标志SQL> select userenv('terminal') from dual;USERENV('TERMINA----------------GAOVSIZE(X)返回X的大小(字节)数SQL> select vsize(user),user from dual;VSIZE(USER) USER----------- ------------------------------6 SYSTEM60.AVG(DISTINCT|ALL)all表示对所有的值求平均值,distinct只对不同的值求平均值SQLWKS> create table table3(xm varchar(8),sal number(7,2));语句已处理。