SELECT单表查询

本篇博客主要介绍了如何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中内部微排
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值