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             表名;
            查询部门表中的管理者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中内部微排

以上是关于MySQL单表查询的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 基础之 单表多表联查

MySQL单表操作

MySQL单表操作

MySQL单表操作

MySQL之单表查询

mysql 单表查询