Oracle数据库之操作符及函数

一、操作符:

1、分类:

算术、比较、逻辑、集合、连接;

2、算术操作符:

    执行数值计算;

-- 工资加1000
select empno,ename,job,sal+1000 from emp;

3、比较操作符:

-- 比较运算符(between and包头不包尾)
select * from emp where sal between 1000 and 2000;

(不等于是!=  ,   在mysql中是<>  )

4、逻辑操作符:and  or  not

--查询奖金不为空的员工信息
select * from emp where comm is  not null;

5、集合操作符:

将两个查询的结果组合成一个结果:

select sid  from t_score where score>=70 and cid = ‘01‘
INTERSECT
select sid from t_score where score>=70 and cid = ‘07‘;

①、intersect 返回两个查询的公共行;

②、union:返回两个查询的不重复的所有行;这里面可以是一个表中的数据(在mysql中是另外的联合查询--不是一个表)

③、minus:返回从第一个查询的结果中排除第二个查询中出现的行;(在第一个的结果中查找不满足第二个的)

6、连接操作符:

  将多个字符串或数据值合并成一个字符串;

--连接操作符
select (‘员工号为‘||empno||‘,姓名为‘||ename||‘的工资为‘||sal) from emp

7、优先级:

算术>连接>比较>not逻辑>and逻辑>or逻辑操作符

二、SQL函数:

    用于执行特殊的操作的函数;

1、分类:

  单行、 分组、分析;

2、单行函数分类:

  从表中查询的每一行只返回一个值;

  字符、数字、日期、转换、其他;

3、字符函数:

-- 字符串函数
select lower(ename),job from emp; --小写

select ltrim(‘xysdezadmas‘,‘xyz‘) from dual;--截取:从左边开始按后面字段开始截取,有几个截取几个,没有就不截取

①、其他字符函数:

chr:根据ASCII码返回对应的字符(0:48    a:97    A:65)

lpad和rpad: 填充;

trim:去除左右两边的空格符;

lenth:字符串长度;

decode:逐个值置换;

select sname,decode(cid,1,‘开发部‘)as 部门 from java0322;

select ename,decode(job,‘CLERK‘,‘职员‘,‘SALESMAN‘,‘导购‘) as 工作 from emp

4、数字函数;

5、日期函数:

  对日期值进行计算,并生成日期数据类型或数值类型的结果;

add_months 偏移;

months_between:月数差;

last_day 最后一天;

round:四舍五入;

trunc:只舍不入,返回指定日期模式截断后的第一天;

next_day(d,day):下周周几的日期

extract:计算年份差:

--日期函数
select add_months(sbirth,-3)  from java0322;--月份偏移3月,可以是负数,也就是向前偏移

select extract(year from sysdate) from dual;--截取当前时间的年份

select sname,extract(year from sysdate) - extract(year from sbirth) from java0322;--计算年纪

6、转换函数:

to_char:按照指定的格式转化字符串;

to_date:将字符串转化为日期;

to_number:将数字字符串转化为数字;----可以实现直接在sql语句中进行格式的转换

--转换函数(字符串,格式)
Select TO_CHAR(0.123,‘$0.9999‘) FROM DUAL;
--字符串转日期
select to_date (‘2005-02-28‘,‘yyyy-mm-dd‘) from dual;
--字符串转数字
select to_number(‘20‘) from dual;

其他函数:

nvl:isnull,不为空时为本身,为空时指定0;

nvl2:不为空时指定值2,为空时指定值3;

NullIF:相等时为空,否则为前者

--查询员工表的所有人的姓名,工资+奖金(奖金没有的时候,由null转为0)---nvl转换空值的函数
select ename,sal+nvl(comm,0)as sal from emp;--当空为0,不为空为comm

select ename,sal+nvl2(comm,10000,0)  from emp;---不为空时10000,为空时0;

select nullif(100,200) from dual;--相等为空,不等为前者

7、分组函数:

  基于一组行来返回结果;

avg、min、max、sum、count

8、分析函数:

  根据一组行来计算聚合值;用于计算完成聚集的累计排名、移动平均数等;

row_number:返回连续的排位,不论值是否相等;

rank:具有相等值的行排位相同,序数随后跳跃;

dense_rank:具有相等值的行排位相同,序号是连续的

-- 排位
select empno,ename,job,sal,row_number()over (order by sal desc) as  numm from emp; --返回连续的排位,不论值是否相等12345

select empno,ename,job,sal,rank()over (order by sal desc) as  numm from emp; --相等值的行排位相同,序号随后跳跃;12245

select empno,ename,job,sal,dense_rank()over (order by sal desc) as  numm from emp; --相等值的行排位相同,序号是连续的;12234

原文地址:https://www.cnblogs.com/21-forever/p/11265585.html

时间: 2024-11-04 03:30:28

Oracle数据库之操作符及函数的相关文章

Oracle数据库基础--存储过程和函数

一.存储过程和函数 存储过程: 对一个模块的封装 函数: 功能与存储过程几乎一样 区别: 函数必须通过return 关键字返回一个值 存储过程: 不需要return返回值 参数: 输入型参数 输出型参数 输入(输出)型参数 什么时候用存储过程, 什么时候用函数 一般来讲, 当只有一个返回值的时候用函数, 当没有返回值或者需要多个返回值的时候, 用存储过程 二.首先看一下SQL基础 先看要举例的表的内容: 下面开始操作: 首先建一个新的SQL Window: DECLARE --声明变量 /* 引

oracle数据库优化与LNNVL函数使用

一:先谈谈数据库的优化 1. max 函数 运行速率慢:现在用下面的方式替换 A;用max函数的方式:获取最新操作时间的 一行员工记录-----------速度慢: select *             from [email protected] JER             WHERE JER.TYPE = '员工银行卡信息记录'                       AND JER.CREATEDATE = (SELECT MAX(CREATEDATE)            

编程开发之--Oracle数据库--存储过程和存储函数(1)

1.存储过程和存储函数 描述:指存储在数据库中供所有用户程序调用的子程序叫做存储过程.存储函数 区别:存储函数可以通过return子句返回一个函数的值 (1)存储过程 语法:create [or replace] PROCEDURE 过程名(参数列表) AS PLSQL子程序体; 存储过程的调用方式: a)exec/execute 过程名(); b)begin 过程名(); 过程名(); end; / 带参数的存储过程: 举例:为指定的员工涨100块钱工资,并且打印涨前以及涨后的工资. 在sql

Oracle数据库,内置函数小结

1.聚合函数 count(字段) // 求非空行的数量 max(字段) // 获取最大值 sum(字段) //求和 avg(字段) // 平均值 min(字段) // 最小值 2.转换函数 to_date() 字符串转时间 格式: to_date(字符串,'yyyy-mm-dd hh24:mi:ss') 例: to_date ('1970-1-1 15:31:33' , 'yyyy-mm-dd hh24: mi: ss ') to_char() 时间转字符串 格式:to_char ( 某个时间,

Oracle数据库数值、日期函数的学习

一.数值函数的学习 1)number(p,s).number(p).number(*,s),p的值为1-38之间. 2)数值类型的兼容性 --:numeric(p,s) 相当于number(p,s) --:decimal(p,s)或dec(p,s) 相当于number(p,s) --:integer或int(不能指定位数)相当于number(38) --:smallint相当于number(38) --:float相当于number --:double precision相当于number --

Oracle数据库速查知识文档

项目介绍 该项目记录了Oracle相关的速查知识汇总,主要涉及了oracle基础使用.SQL基础.oracle函数.oracle触发器.oracle高级查询.PL/SQL编程基础.PL/SQL存储过程等.若有新增,还将不断添加中. SQL基础部分 1.简介 Oracle Database,又名Oracle RDBMS,或简称Oracle,是甲骨文公司的一款关系数据库管理系统.本课程主要介绍Oracle的SQL基础,包括表空间的概念,如何登录Oracle数据库,如何管理表及表中的数据,以及约束的应

Oracle数据库之安装教程

一.从官网下载oracle数据库或者我的博客 官网地址:Oracle数据库下载地址 博客地址:博客下载地址 二.安装数据库 注意: 10g的数据库只能在xp操作系统中才有效. 建议安装在虚拟机上,这样随便玩都行. xp镜像下载地址:地址 1.运行安装程序Setup.exe,系统将启动Oracle Universal Installer,然后进行先决条件检查.会出现如下图示 2.然后一路next,到最后一步的时候需要配置一下你的登录信息 3. 安装完成后,自动运行配置向导,如下图,等待其完成: 4

解决oracle数据库中 ORA-01843: 无效的月份问题

1.这是因为客户端是中文环境,格式mon就不能用英文的月份写法,必须用中文的“六月”如果不想修改sql语句运行的话,就需要在执行该语句之前,使用alter session 命令将nls_date_language修改为american,如下:alter session set nls_date_language='american'以英语显示日期. 2若你的客户端是英文环境,那就是你没有用oracle数据的时间函数查询数据,应在sql语句中使用oracle数据库中的时间函数.

Oracle数据库入门——sql语句和函数详解

一.oracle常用数据类型 一.  数据定义语言(ddl) 数据定义语言ddl(data definition language)用于改变数据库结构,包括创建.更改和删除数据库对象. 用于操纵表结构的数据定义语言命令有: create table alter table truncate table drop table eg. --创建tb_stu表数据结构 create table tb_stu( id number, name varchar2(20) );   --修改tb_stu表数