本篇博客主要介绍了如何SELECT进行单表查询,怎样使用WHERE结合各种运算符对数据进行过滤,如何使用ORDER BY 子句
查询
概述:使用数据库保存数据,我们对数据库的操作主要是增,删,改,查操作,其中从数据库中查询数据更为基础,使用不同的查询方式,具有不同的查询效率。
数据库中数据的保存形式:
数据在数据库中以表格的形式保存:
一个库可以保存多个表,我们可以从不同的表中查询数据信息。
SELECT语句
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也可以省略)
别名使用双引号,可以在别名中包含空格或特殊的字符并区分大小写。(双引号非必须)
|
查询部门表中管理者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中内部微排 |