前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何SELECT进行单表查询,怎样使用WHERE结合各种运算符对数据进行过滤,如何使用ORDER BY 子句 查询

如何SELECT进行单表查询,怎样使用WHERE结合各种运算符对数据进行过滤,如何使用ORDER BY 子句 查询

作者头像
一头小山猪
发布2020-04-10 10:55:46
3.5K0
发布2020-04-10 10:55:46
举报
文章被收录于专栏:微光点亮星辰

查询

概述:使用数据库保存数据,我们对数据库的操作主要是增,删,改,查操作,其中从数据库中查询数据更为基础,使用不同的查询方式,具有不同的查询效率。

数据库中数据的保存形式:

数据在数据库中以表格的形式保存:

一个库可以保存多个表,我们可以从不同的表中查询数据信息。

SELECT语句

SELECT 标识选择哪些列

FROM 标识从哪个表中选择

选择全部列 SELECT * FROM 表名; 查询表中的所有数据/查询所有列

查询部门表的所有数据

SELECT * FROM departments;

选择特定的列 SELECT 列名1, 列名2, ... FROM 表名;

查询部门表中的管理者id和部门名称

SELECT

manager_id, department_name

FROM

departments;

小结:

① 虚表的列由SELECT后面FROM前面的内容决定

② 每个sql语句最后都以";"结尾

③ FROM表示从某一表中获取目标列

④ 不同的列名之间用","分割

注意事项: SQL 语言大小写不敏感。 SQL 可以写在一行或者多行。 关键字不能被缩写(简写)也不能分行 。 各子句一般要分行写。 使用缩进提高语句的可读性。

列的别名

列的别名: 重命名一个列。

使用方式: 紧跟列名,也可以在列名和别名之间加入关键字‘AS'。(AS也可以省略) 别名使用双引号,可以在别名中包含空格或特殊的字符并区分大小写。(双引号非必须)

原始列名 AS 新列名

查询部门表中管理者id和部门名称,并分别起个别名

SELECT

manager_id AS manager,

manager_id,

department_name "dept name"

FROM

departments;

字符串

字符串可以是 SELECT 列表中的一个字符,数字,日期。 日期和字符只能在单引号中出现。 每当返回一行时,字符串被输出一次。

过滤和排序数据

过滤: 对于查询到的数据使用某些自定义条件进行筛选

WHERE子句

SELECT 列名1, 列名2 , ...FROM 表名WHERE 过滤条件;

使用WHERE 子句,将不满足条件的行过滤掉。WHERE 子句紧随 FROM 子句。 WHERE在查询的语句中起到过滤的作用,参与虚表的构建,让信息有条件的显示。

查询部门id为90的员工的名字和薪水

SELECT

last_name,salary

FROM

employees

WHERE

department_id = 90;

比较运算符

补充:赋值使用 := 符号

在使用WHERE子句过滤数据的时候可以使用比较运算符

查询薪水小于3000的员工的名字和薪水

SELECT

last_name, salary

FROM

employees em

WHERE

em.salary < 3000;

查询满足where条件的员工的名字和薪水

SELECT

last_name, salary

FROM

employees

WHERE

8 - 9; // 算术表达式结果为0表示假, 其他则为真

其它比较运算

AND

查询薪水小于20000并且部门id为90的员工的名字

SELECT

last_name, salary

FROM

employees em

WHERE

em.salary < 20000

AND

em.department_id = 90;

BETWEEN

使用 BETWEEN 运算来显示在一个区间内的值

查询工资在2500到3500之间的员工

SELECT

last_name, salary

FROM

employees

WHERE

salary BETWEEN 2500 AND 3500;

含义:salary >= 2500 AND salary <= 3500

IN

IN表示在某个集合中

查询管理者id为100或者101或者201的员工id,姓名,薪水,管理者id

SELECT

employee_id,

last_name, salary,

manager_id

FROM

employees

WHERE

manager_id IN (100, 101, 201);

含义:manager_id = 100 OR manager_id = 101 OR manager_id = 201

LIKE(模糊查询 )

使用 LIKE 运算选择类似的值 选择条件可以包含字符或数字: % 代表零个或多个字符(任意个字符)。 _ 代表一个字符。 %,_可以同时使用

1.查询名字中前两个字母是ch的字母

SELECT

*

FROM

country

WHERE

name LIKE 'ch%';

2.查询国家名称中包含x的国家

SELECT

*

FROM

country

WHERE

name LIKE '%x%';

3.查询城市名称中第3个字母是a的城市

SELECT

*

FROM

city

WHERE

name LIKE '__a%';

NULL

使用 IS (NOT) NULL 判断空值。

查询哪些国家没有首都

SELECT

*

FROM

country

WHERE

capital IS NULL;

逻辑运算

AND

要求并的关系为真

查询薪水大于等于1000并且job_id中有MAN字符的员工id,姓名,工作id,薪水

SELECT

employee_id, last_name, job_id, salary

FROM

employees

WHERE

salary >=10000

AND

job_id LIKE '%MAN%';

OR

要求或关系为真

查询薪水小于20000或者部门id为90的员工的名字

SELECT

last_name, salary

FROM

employees em

WHERE

em.salary < 20000

OR

em.department_id = 90;

NOT

查询工作id不是'IT_PROG', 'ST_CLERK', 'SA_REP'任意一个的员工姓名,工作id

SELECT

last_name, job_id

FROM

employees

WHERE

job_id NOT IN ('IT_PROG', 'ST_CLERK', 'SA_REP');

含义: WHERE job_id != IT_PROG AND job_id != ST_CLERK AND job_id != 'SA_REP';

ORDER BY 子句

对虚表的记录进行排序, 所以通常是在虚表的记录确定下来以后.

使用 ORDER BY 子句排序 ASC(ascend): 升序(默认方式) DESC(descend): 降序ORDER BY 子句在SELECT语句的结尾。

按照工资升序排序,默认升序

SELECT

last_name, job_id, department_id, salary

FROM

employees

ORDER BY

salary ASC;

按照工资降序排序

SELECT

last_name, job_id, department_id, salary

FROM

employees

ORDER BY

salary DESC;

按别名排序

按照年工资升序排序

SELECT

employee_id, last_name, salary*12 annsal

FROM

employees

ORDER BY

annsal;

多个列排序

根据部门id和工资排序

SELECT

last_name, department_id, salary

FROM

employees

ORDER BY

department_id, salary DESC;

说明:先依据部门ID升序, 在相同的部门ID中内部微排

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2016-11-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微光点亮星辰 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档