MySQL单表查询
Posted Nothing_doit
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL单表查询相关的知识,希望对你有一定的参考价值。
本篇博客主要介绍了如何SELECT进行单表查询,怎样使用WHERE结合各种运算符对数据进行过滤,如何使用ORDER BY 子句查询
概述:使用数据库保存数据,我们对数据库的操作主要是增,删,改,查操作,其中从数据库中查询数据更为基础,使用不同的查询方式,具有不同的查询效率。数据库中数据的保存形式: 数据在数据库中以表格的形式保存:
一个库可以保存多个表,我们可以从不同的表中查询数据信息。
SELECT语句
SELECT
SELECT 标识选择哪些列 FROM 标识从哪个表中选择选择全部列 SELECT * FROM 表名; 查询表中的所有数据/查询所有列 |
查询部门表的所有数据 SELECT * FROM departments;
选择特定的列 SELECT 列名1, 列名2, ... FROM 表名; |
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中内部微排 |
以上是关于MySQL单表查询的主要内容,如果未能解决你的问题,请参考以下文章