DQL 表查询操作

数据准备:

1.需导入该测试数据库

测试数据库

  • https://github.com/datacharmer/test_db

2.赋予权限

cd 数据所在目录

mysql -h 127.0.0.1 -uroot -p < employees.sql

 

因为我的workbench一直不能用root登录上去,一直报

ERROR 1698 (28000): Access denied for user 'root'@'localhost'

上网寻找解决方法无果,则只能新建一个账户并赋予这个数据库的权限给他

具体参考这个帖子新建账户

https://blog.csdn.net/qq_49175846/article/details/116356268

GRANT ALL PRIVILEGES ON weixx.* TO wxx@"%" IDENTIFIED BY "654321"; 
weixx.* :需要赋予权限的数据库
wxx:新建的账户名
654321:密码
查看当前有多少个用户:
mysql> select user,host from mysql.user;
+------------------+-----------+
| user             | host      |
+------------------+-----------+
| root             | %         |
| wxx              | %         |
| debian-sys-maint | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
| root             | localhost |
+------------------+-----------+

查看用户权限:
mysql> show grants for 'wxx'@'%';
+-----------------------------------------------------------+
| Grants for wxx@%                                          |
+-----------------------------------------------------------+
| GRANT USAGE ON *.* TO 'wxx'@'%'                           |
| GRANT ALL PRIVILEGES ON `employees`.* TO 'wxx'@'%'        |
| GRANT ALL PRIVILEGES ON `test_for_manshuo`.* TO 'wxx'@'%' |
+-----------------------------------------------------------+
3 rows in set (0.00 sec)

3.准备就绪
测试数据库是employees


单表查询

  • 单表查询:从一张表中查询所需要的数据,所有查询操作都比较简单
  • * 代表所有的列
  • 语法:SELECT * FROM 表名;
-- 查询部门表中的信息
SELECT * FROM departments;


字段查询

  • 查询多个字段(列),可以使用 , 对字段进行分隔
  • 语法:SELECT 列名 FROM 表名;
-- 查询部门的名称
SELECT dept_name FROM departments;

起别名

  • 为表起别名:
    • SELECT 列名 FROM 表名 表别名;
  • 为字段起别名:SELECT 列名 AS 别名 FROM 表名

 

-- 查询员工信息,并将列名改为中文
SELECT emp_no AS '编号', first_name AS '名', last_name AS '姓', gender AS '性别', hire_date AS '入职时间' FROM employees emp;
 

去重

  • DISTINCT 关键字:去掉重复信息
  • 语法:SELECT DISTINCT 列名 FROM 表名;

 

-- 去掉重复职级信息 
SELECT DISTINCT title FROM titles;

运算查询

  • 查询结果参与运算
    • SELECT (列名 运算表达式) FROM 表名;
-- 所有员工的工资 +1000 元进行显示
SELECT emp_no , salary + 1000 FROM salaries;



DQL 表查询操作 - 条件查询

条件查询语法

-- 条件查询
SELECT 列名 FROM 表名 WHERE 条件表达式

比较运算符

 
运算符说明
> < <= >= = <> != 大于、小于、小于等于、大于等于、等于、不等于
BETWEEN...AND... 范围限定
IN 子集限定
LIKE '%or%' 模糊查询
IS NULL 为空

比较大小

  • 语法:WHERE <列名> [> < <= >= = <> !=] <值>
-- 查询出生日期晚于 1965-01-01 的员工编号、姓名和生日
SELECT 
    emp_no, first_name, last_name, birth_date
FROM
    employees
WHERE
    birth_date > '1965-01-01';

使用 BETWEEN 进行模糊查询

 
  • 语法:WHERE <列名> [NOT] BETWEEN <起始表达式> AND <结束表达式>
  • <起始表达式><结束表达式> 的顺序不能颠倒
-- 查询年薪介于 70000 到 70003 之间的员工编号和年薪
SELECT 
    emp_no, salary
FROM
    salaries
WHERE
    salary BETWEEN 70000 AND 70003;

使用 IN 进行模糊查询

 
  • 语法:WHERE <列名> IN <(常量列表)>
  • (常量列表) 中各常量值用逗号隔开
-- 查询入职日期为 1995-01-27 和 1995-03-20 日的员工信息
SELECT 
    *
FROM
    employees
WHERE
    hire_date IN ('1995-01-27', '1995-03-20');

判断是否为空

 
  • 语法:WHERE <列名> IS [NOT] NULL
-- 选择 hog_demo 为当前数据库
USE hog_demo;

-- 更新 student 表中 id 为 2 的 age 值为 NULL
UPDATE student SET age = NULL WHERE id = 2;

-- 查询学生表中年龄为 NULL 的学生信息
SELECT 
    *
FROM
    student
WHERE
    age IS NULL;

逻辑运算符

 
运算符说明
AND && 多个条件同时成立
OR || 多个条件任一成立
NOT 不成立
- 查询名字为 Lillian 并且姓氏为 Haddadi 的员工信息
SELECT 
    *
FROM
    employees
WHERE
    first_name = 'Lillian'
        AND last_name = 'Haddadi';

-- 查询名字为 Lillian 或者姓氏为 Terkki 的员工信息
SELECT 
    *
FROM
    employees
WHERE
    first_name = 'Lillian'
        OR last_name = 'Terkki';

-- 查询名字为 Lillian 并且性别不是女的员工信息
SELECT 
    *
FROM
    employees
WHERE
   first_name = 'Lillian'
   and not gender='F';

通配符

运算符说明
% 匹配任意多个字符
- 匹配一个字符
-- 查询名字中包含 fai 的员工的信息
SELECT 
    *
FROM
    employees
WHERE
    first_name LIKE '%fai%';

-- 查询名字中 fa 开头的名字长度为 3 位的员工信息
SELECT 
    *
FROM
    employees
WHERE
    first_name LIKE 'fa_';

排序语法

  • ASC 表示升序排序(默认)
  • DESC 表示降序排序
-- 对查询结果进行排序
SELECT 列名 FROM 表名 
[WHERE 条件表达式] 
ORDER BY 列名1 [ASC / DESC],
列名2 [ASC / DESC]


单列排序

  • 只按照某一个列进行排序, 就是单列排序
-- 使用 salary 字段,对 salaries 表数据进行升序排序
SELECT * FROM salaries ORDER BY salary;

-- 使用 salary 字段,对 salaries 表数据进行降序排序
SELECT * FROM salaries ORDER BY salary DESC;

-- 查询员工的编号和入职日期,按照员工入职日期从晚到早排序
SELECT 
    emp_no, hire_date
FROM
    employees
ORDER BY hire_date DESC;

组合排序

  • 同时对多个字段进行排序
  • 如果第一个字段相同,就按照第二个字段进行排序
-- 在入职时间排序的基础上,再使用 emp_no 进行排序
-- 组合排序 
SELECT 
    emp_no, hire_date
FROM
    employees
ORDER BY hire_date DESC, emp_no DESC;
 
 
 
posted @ 2022-04-16 17:27  lms21  阅读(75)  评论(0)    收藏  举报