Oracle中简单查询、限定查询、数据排序SQL语句范例和详细注解

一、简单查询

SQL(Structured Query Language) 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。ANSI(美国国家标准学会)声称,SQL是关系数据库管理系统的标准语言。
Oracle数据库之所以发展的很好,主要也是因为Oracle是全世界最早采用SQL语句的数据库产品。
SQL功能强大,概括起来,它可以分成以下几组:

代码如下:

DML(Data Manipulation Language) 数据操作语言,用于检索或者修改数据
DDL(Data Definition Language) 数据定义语言,用于定义数据的结构,创建、修改或者删除数据库对象
DCL(Data Control Language) 数据控制语言,用于定义数据库的权限

简单查询指的是查询出一张表中的所有的数据,简单查询的语法如下:

代码如下:

SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名]] FROM 表名称 [别名];

范例:

SELECT * FROM dept;--查询dept表的全部记录
SELECT empno, ename, sal FROM emp;--查询出每个雇员的编号、姓名、基本工资
SELECT job FROM emp;--查询出每个雇员的职位。这个时候发现查询出来的job内容中出现了重复的数据。
SELECT DISTINCT job FROM emp;--使用DISTINCT消除掉所有的重复内容。但是对于重复数据,指的是一行中的每个列的记录都重复,才叫重复数据。
SELECT DISTINCT ename, job FROM emp;--查询出每个雇员的姓名、职位
SELECT ename, job, sal*12 FROM emp;--使用各个数学的四则运算符,要求显示每一个雇员的姓名、职位、基本年薪
SELECT ename, job, sal*12 income FROM emp;--为显示的查询列起一个别名,对于别名,建议不要使用中文,只要是程序的开发,都要回避中文。
SELECT ename, job, (sal+300)*12 income FROM emp;--由于公司的福利很高,每个月都有200元的饭食补助以及100元车费补贴,这个时候的年薪
SELECT ename, job, (sal+300)*12+sal income FROM emp;--公司每年的年底都会多发一个月的基本工资
SELECT empno || ',' || ename FROM emp;--在简单查询中也可以使用“||”连接查询的字段。
SELECT '雇员编号是:' || empno || '的雇员姓名是:' || ename || ',基本工资是:' || sal || ',职位是:' || job || '! ' 雇员信息 FROM emp;--要求现在的数据库按照如下的格式显示:“雇员编号是:7369的雇员姓名是:SMITH,基本工资是:800,职位是:CLERK!” 

由于“,”属于原样输出的字符串,所以必须使用“ ' ”括起来,即:在SQL语句之中,“ ' ”表示的是字符串。
一定要记住,别名上的内容不要使用“ ' ”括起来,而只有在SELECT子句之中出现的内容使用“ ' ”。

二、限定查询

在之前的简单查询中,是将所有的记录进行显示,但是现在可以对显示的记录进行过滤的操作,而这就属于限定查询的工作了,限定查询就是在之前语法的基础上增加了一个WHERE子句,用于指定限定条件,此时语法如下:

代码如下:

SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名]]  
FROM 表名称 [别名]  
[WHERE 条件(S)];

在WHERE子句之后可以增加多个条件,最常见的条件就是基本的关系运算:>、>=、< 、<=、!=(<>)、BETWEEN、AND、LIKE、IN、IS NULL、AND、OR、NOT;

1、关系运算

SELECT * FROM emp WHERE sal>1500;--要求查询出基本工资高于1500的所有雇员信息
SELECT * FROM emp WHERE job='clerk';--查询出所有职位是办事员的雇员信息
SELECT * FROM emp WHERE job='CLERK';--上面没有返回相应的查询结果,主要原因是在Oracle数据库中,所有的数据都是区分大小写的
SELECT * FROM emp WHERE sal>=1500 AND sal<=3000;--查询工资在1500~3000之间的全部雇员信息,多个条件之间可以使用AND或OR进行连接操作
SELECT * FROM emp WHERE job='CLERK' OR job='SALESMAN';--查询出职位是办事员,或者是销售人员的全部信息
SELECT * FROM emp WHERE (job='CLERK' OR job='SALESMAN') AND sal>1200;--查询出职位是办事员,或者是销售人员的全部信息,并且要求这些雇员的工资大于1200
SELECT * FROM emp WHERE job<>'CLERK';--查询所有不是办事员的雇员信息
SELECT * FROM emp WHERE job!='CLERK';
SELECT * FROM emp WHERE NOT job='CLERK'; 

2、范围判断:BETWEEN…AND…

“BETWEEN 最小值 AND 最大值”,表示的是一个范围的判断过程。“BETWEEN…AND…”操作符不光只是针对于数字有用,对于日期也同样有用。

代码如下:

SELECT * FROM emp WHERE sal BETWEEN 1500 AND 3000;--要求查询出基本工资在1500~3000的雇员信息  
SELECT * FROM emp WHERE NOT sal BETWEEN 1500 AND 3000;--现在也可以对BETWEEN…AND…操作求反  
SELECT * FROM emp WHERE hiredate BETWEEN '01-1月-1981' AND '31-12月-81';--要求查询出在时间范围内的全部雇员信息

3、判断是否为空:IS (NOT) NULL

使用此语法可以判断某一个字段上的内容是否是“null”,但是null和数字0以及空字符串是两个概念。

代码如下:

SELECT * FROM emp WHERE comm IS NOT NULL;--查询出所有领取奖金的雇员信息  
SELECT * FROM emp WHERE NOT comm IS NULL;  
SELECT * FROM emp WHERE comm IS NULL;--查询出所有不领取奖金的雇员

4、指定范围的判断:IN操作符

IN操作符表示的是指定一个查询的范围

SELECT * FROM emp WHERE empno=7369 OR empno=7566 OR empno=7799;--使用OR操作查询出雇员编号是7369、7566、7799的雇员信息
SELECT * FROM emp WHERE empno IN (7369,7566,7799);--使用IN操作查询出雇员编号是7369、7566、7799的雇员信息
SELECT * FROM emp WHERE empno NOT IN (7369,7566,7799);使用NOT IN操作查询出雇员编号不是7369、7566、7799的雇员信息
SELECT * FROM emp WHERE empno IN(7369,7566,null);--使用了IN操作符,查询的范围之中存在了null,不影响查询;
SELECT * FROM emp WHERE empno NOT IN(7369,7566,null);--使用的是NOT IN操作符,如果查询范围之中有了null则表示的就是查询全部数据。 

5、模糊查询:LIKE子句
LIKE子句的功能是提供了模糊查找的操作,例如:某些程序上出现的搜索操作,都属于LIKE子句的实现,但是必须提醒的,搜索引擎上的查询可不是LIKE。但是要想使用LIKE子句则必须认识两个匹配符号:

代码如下:

匹配单个字符:_; -> 1个
匹配任意多个字符:%; -> 0个、1个、多个

SELECT * FROM emp WHERE ename LIKE 'A%';--要求查询雇员姓名中以字母A开头的全部雇员信息
SELECT * FROM emp WHERE ename LIKE '_A%';--要求查询出雇员姓名中第二个字母是A的全部雇员信息
SELECT * FROM emp WHERE ename LIKE '%A%';--要求查询出雇员姓名中带有字母A的雇员
SELECT * FROM emp WHERE ename NOT LIKE '%A%';--使用NOT操作,对操作进行求反的功能
SELECT * FROM emp WHERE ename LIKE '%1%' OR hiredate LIKE '%1%' OR sal LIKE '%1%';--对于LIKE子句,可以在任意的数据上表示:

在开发之中,数据库的模糊查询肯定使用LIKE子句,但是在使用LIKE子句的时候有一个最大的注意点:如果在模糊查询上不设置任何的查询关键字的话('%%')则表示查询全部记录:

代码如下:

SELECT * FROM emp WHERE ename LIKE '%%' OR hiredate LIKE '%%' OR sal LIKE '%%';

三、数据的排序

当数据返回查询结果之后,所有的数据默认情况下是按照雇员编号排序的,当然,现在也可以使用”ORDER BY”子句指定所需要的排序的操作列,而这个时候的SQL语法如下:

代码如下:

SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名]]  
FROM 表名称 [别名]  
[WHERE 条件(S)]  
[ORDER BY 字段 [ASC|DESC] [,字段 [ASC|DESC],…]];

“ORDER BY”子句是写在所有的SQL语句最后的内容,而且对于排序有以下几点说明:
排序的时候可以指定多个排序的字段;
排序的方式有两种:1、升序(ASC):默认,不写也是升序;2、降序(DESC):用户需要指定,由大到小排序;

SELECT * FROM emp ORDER BY sal;--查询所有的雇员的信息,要求按照工资排序
SELECT * FROM emp ORDER BY sal ASC;
SELECT * FROM emp ORDER BY sal DESC;--进行降序排列
SELECT * FROM emp ORDER BY sal DESC, hiredate ASC;--查询出所有的雇员信息,按照工资由高到低排序,如果工资相同,则按照雇佣日期由早到晚排序 

对于排序操作,一般只在需要的地方上使用,而且一定要记住的是,ORDER BY 子句是写在所有的SQL语句的最后的部分。

(0)

相关推荐

  • Oracle实现分页查询的SQL语法汇总

    本文实例汇总了Oracle实现分页查询的SQL语法,整理给大家供大家参考之用,详情如下: 1.无ORDER BY排序的写法.(效率最高) 经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然! sql语句如下: SELECT * FROM (Select ROWNUM AS ROWNO, T.* from k_task T where Flight_date between to_date('20060501', 'yyyymmdd') and to_d

  • Oracle 查询表信息获取表字段及字段注释

    获取表字段: select * from user_tab_columns where Table_Name='用户表' order by column_name 获取表注释: select * from user_tab_comments where Table_Name='用户表' order by Table_Name 获取字段注释: select * from user_col_comments where Table_Name='用户表' order by column_name /*

  • oracle跨库查询dblink的用法实例详解

    本文实例讲述了oracle跨库查询dblink的用法.分享给大家供大家参考,具体如下: 1.创建之前的工作 在创建dblink之前,首先要查看用户是否有相应的权限.针对特定的用户,使用 sqlplus user/pwd登录后,执行如下语句: 复制代码 代码如下: select * from user_sys_privs t where t.privilege like upper('%link%'); 在sys用户下,显示结果为: SYS CREATE DATABASE LINK NO SYS

  • oracle数据库在客户端建立dblink语法

    oracle服务器没有建立目标数据库的TNS时,在客户端(有权限的情况下)建立dblink语法如下: 复制代码 代码如下: create database link dblink_name connect to user_name identified by user_psw using '(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xx.xxx.xx)(PORT = 1521)) ) (CONNEC

  • Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出

    ORDER BY非稳定的排序 提一个问题: oracle在order by 排序时,是稳定排序算法吗? 发现用一个type进行排序后,做分页查询,第一页的数据和第二页的数据有重复 怀疑是order by 时,两次排列的顺序不一致 看到业务描述的问题可以得到的结论order by排序不稳定,还有第一个印象就是,type肯定是不唯一的,并且没有索引吧. 这里先科普下排序的稳定性,举个最简单的例子,1,2,3,1,4,5 排序 排序的结果是1,1,2,3,4,5,这时候观察这个1,如果第一个1还是排序

  • Oracle 跨库 查询 复制表数据 分布式查询介绍

    方法一: 在目前绝大部分数据库有分布式查询的需要.下面简单的介绍如何在oracle中配置实现跨库访问. 比如现在有2个数据库服务器,安装了2个数据库.数据库server A和B.现在来实现在A库中访问B的数据库. 第一步.配置A服务器端的tnsnames.ora文件(TNSNAMES.ORA Network Configuration File),该文件存放的位置为: $ORACLE_HOME/network/admin/tnsnames.ora 添加如下行,其中DBLINK为连接名(可自定义)

  • Oracle10g通过DBLink访问MySQL示例

    1, 首先在Oracle所在计算机安装MySQL的Client端软件,并且x86_64和i386版本的都需要安装,以便可以连接MySQL数据库.查看Client安装情况: 复制代码 代码如下: rpm -qa |grep mysql mysql-5.0.45-7.el5 mysql-5.0.45-7.el5 得到两条记录,一条是x86_64的,一条是i386的.如果看到还没有安装mysql客户端软件,则需要安装: 复制代码 代码如下: yum install mysql yum install

  • ORACLE学习笔记-查询篇

    一.普通查询 /*查询表数据*/ select * from STU /*取出前3行数据*/ select * from stu where ROWNUM<=3 /*模糊查询*/ select * from stu where stu_id like 'stu001%' 说明:通配符"%"代表一个或者多个字符,通配符"_"代表一个字符. /*别名*/ select STU_ID as 学号 from stu 二.联合查询 /*普通联合查询*/ SELECT S

  • Oracle中简单查询、限定查询、数据排序SQL语句范例和详细注解

    一.简单查询 SQL(Structured Query Language) 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理关系数据库系统.ANSI(美国国家标准学会)声称,SQL是关系数据库管理系统的标准语言. Oracle数据库之所以发展的很好,主要也是因为Oracle是全世界最早采用SQL语句的数据库产品. SQL功能强大,概括起来,它可以分成以下几组: 复制代码 代码如下: DML(Data Manipulation Language) 数据操作语言,用于

  • 查询Oracle中正在执行和执行过的SQL语句

    查询Oracle正在执行的sql语句及执行该语句的用户 SELECT b.sid oracleID, b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, paddr, sql_text 正在执行的SQL, b.machine 计算机名 FROM v$process a, v$session b, v$sqlarea c WHERE a.addr = b.paddr AND b.sql_hash_value = c.hash_value 其它网友给出的正

  • oracle中利用关键字rownum查询前20名员工信息及rownum用法

    注意:对 rownum(伪列) 只能使用 < 或 <=, 而用 =, >, >= 都将不能返回任何数据 例:查询工资前20名的员工姓名,工资 ,工资由高到低 Select rownum,first_name,salary from (Select first_name, salary from employees Group by salary desc) Where rownum=<20 如果直接按如下查询得下图结果,显然不正确的,rownum(伪列) 是按查询顺序来排列的

  • PGSQL查询最近N天的数据及SQL语句实现替换字段内容

    目录 1.用SQL查询最近N天的数据 2.用SQL语句实现替换字段里的内容 3.SQL将查询结果赋值 4.SQL查询字段内容为 NULL值时候赋值 总结 1.用SQL查询最近N天的数据 思路:先获取当前的时间,然后更具当前时间去减去对应的天数,就可以得到需要的天数了.然后用这些天数作为条件,然后即可查询出需要多少天的数据了. -- 获取当前时间 SELECT CURRENT_TIMESTAMP; -- 或 SELECT now(); select CURRENT_TIMESTAMP :: DAT

  • 复制数据库表中两个字段数据的SQL语句

    复制数据库表中两个字段数据的SQL语句 今天为表新添加一个字段,但又想与表中的另一个字段值相同,由于数据过多想通过sql语句实现,经测试下面的这句话确实很好用. 复制代码 代码如下: update jb51_temp set B=A jb51_temp 代表表明 A是有数值的字段,B是新添加的字段 ,记住空值表放到前面,如果set a=b,那么你的数值都为空了,就麻烦了,建议操作前备份数据库. 如何将一个字段里的值复制添加到另一个字段中 比如,有二个字段A和B,A字段是值是"我",B字

  • MySQL根据某一个或者多个字段查找重复数据的sql语句

    sql 查出一张表中重复的所有记录数据 1.表中有id和name 两个字段,查询出name重复的所有数据 select * from xi a where (a.username) in (select username from xi group by username having count(*) > 1) 2.查询出所有数据进行分组之后,和重复数据的重复次数的查询数据,先列下: select count(username) as '重复次数',username from xi group

  • MySql中sql语句执行过程详细讲解

    目录 前言: sql语句的执行过程: 查询缓存: 分析器: 优化器: 执行器: 总结 前言: 很多人都在使用mysql数据库,但是很少有人能够说出来整个sql语句的执行过程是怎样的,如果不了解执行过程的话,就很难进行sql语句的优化处理,也很难设计出来优良的数据库表结构.这篇文章主要是讲解一下sql语句的执行过程. sql语句的执行过程: 客户端.连接器.分析器.优化器.执行器.存储引擎几个阶段. 连接器的作用:管理链接.权限验证的处理. 分析器的作用:词法分析.语法分析. 优化器的作用:执行计

  • 如何让docker中的mysql启动时自动执行sql语句

    在用docker创建mysql容器的时,有时候我们期望容器启动后数据库和表已经自动建好,初始化数据也已自动录入,也就是说容器启动后我们就能直接连上容器中的数据库,使用其中的数据了. 其实mysql的官方镜像是支持这个能力的,在容器启动的时候自动执行指定的sql脚本或者shell脚本,我们一起来看看mysql官方镜像的Dockerfile,如下图: 已经设定了ENTRYPOINT,里面会调用/entrypoint.sh这个脚本,我们把mysql:8这个镜像pull到本地,再用docker run启

  • oracle中如何删除亿级数据

    目录 oracle删除亿级数据 1.drop table ,然后再create table,插入数据 2.使用delete批量删除 3.使用truncate table ,然后再插入数据 oracle数据库亿级数据量清理SQL优化常识 第一种方法就是DELETE 第二种方法就是truncate 删除的第三种方式就是DROP 总结 oracle删除亿级数据 近期遇到一个日志表记录了几年数据,数据量较大(几亿数据),导致查询等操作较慢,为了提高效率,决定删除部分历史数据,想了三种方法如下: 通用步骤

  • mysql 查询重复的数据的SQL优化方案

    在mysql中查询不区分大小写重复的数据,往往会用到子查询,并在子查询中使用upper函数来将条件转化为大写.如: 复制代码 代码如下: select * from staticcatalogue WHERE UPPER(Source) IN (SELECT UPPER(Source) FROM staticcatalogue GROUP BY UPPER(Source) having count(UPPER(Source))>1) ORDER BY upper(Source) DESC; 这条

随机推荐