Linux云计算 |【第四阶段】RDBMS1-DAY3

主要内容:

子查询(单行单列、多行单列、单行多列、多行多列)、分页查询limit、联合查询union、插入语句、修改语句、删除语句

一、子查询

子查询就是指的在一个完整的查询语句之中,嵌套若干个不同功能的小查询,从而一起完成复杂查询的一种编写形式;

1)子查询返回的数据分类

  • 单行单列:返回的是一个具体列的内容,可以理解为一个单值数据
  • 单行多列:返回一行数据中多个列的内容
  • 多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围
  • 多行多列:查询返回的结果是一张临时表

2)子查询常出现的位置

- select之后:仅支持单行单列

- from之后:支持多行多列

- where或having之后:支持单行单列、单行多列、多行单列

子查询应用实例

1)单行单列

例如:查询运维部所有员工信息

① 分析:首先从departments部门表中查出运维部的编号

mysql> select dept_id from departments where dept_name='运维部';
+---------+
| dept_id |
+---------+
|       3 |
+---------+
1 row in set (0.00 sec)

② 组合:再从employees员工表中查找该部门编号和运维部编号相同的员工;

mysql> select * from employees -> where dept_id=(select dept_id from departments where dept_name='运维部');
+-------------+-----------+------------+------------+--------------------+--------------+---------+
| employee_id | name      | hire_date  | birth_date | email              | phone_number | dept_id |
+-------------+-----------+------------+------------+--------------------+--------------+---------+
|          14 | 廖娜      | 2012-05-20 | 1982-06-22 | liaona@tarena.com  | 15827928192  |       3 |
|          15 | 窦红梅    | 2018-03-16 | 1971-09-09 | douhongmei@tedu.cn | 15004739483  |       3 |
|          16 | 聂想      | 2018-09-09 | 1999-06-05 | niexiang@tedu.cn   | 15501892446  |       3 |
|          17 | 陈阳      | 2004-09-16 | 1991-04-10 | chenyang@tedu.cn   | 15565662056  |       3 |
|          18 | 戴璐      | 2001-11-30 | 1975-05-16 | dailu@tedu.cn      | 13465236095  |       3 |
|          19 | 陈斌      | 2019-07-04 | 2000-01-22 | chenbin@tarena.com | 13621656037  |       3 |
+-------------+-----------+------------+------------+--------------------+--------------+---------+
6 rows in set (0.00 sec)

例如:查询2018年12月所有比100号员工基本工资高的工资信息

① 分析:首先查询2018年12月100号员工的基本工资

mysql> select basic from salary-> WHERE YEAR(date)=2018 and MONTH(date)=12 and employee_id=100;
+-------+
| basic |
+-------+
| 14585 |
+-------+
1 row in set (0.00 sec)

② 组合:再查询2018年12月所有比100号员工基本工资高的工资信息

mysql> select employee_id,date,basic from salary-> where YEAR(date)=2018 and MONTH(date)=12-> and basic>(select basic from salary WHERE YEAR(date)=2018 and MONTH(date)=12 and employee_id=100);
+-------------+------------+-------+
| employee_id | date       | basic |
+-------------+------------+-------+
|           1 | 2018-12-10 | 17016 |
|           2 | 2018-12-10 | 20662 |
|           4 | 2018-12-10 | 17016 |
|         127 | 2018-12-10 | 17016 |
+-------------+------------+-------+
65 rows in set (0.00 sec)

③ 扩展:通过内连接,查询2018年12月所有比100号员工基本工资高的工资信息

mysql> select s.employee_id,date,basic,name from salary s-> inner join employees e-> on s.employee_id = e.employee_id-> where year(date)=2018 and month(date)=12 and basic > (-> select basic from salary where year(date)=2018 and month(date)=12 and employee_id=100);
+-------------+------------+-------+-----------+
| employee_id | date       | basic | name      |
+-------------+------------+-------+-----------+
|           1 | 2018-12-10 | 17016 | 梁伟      |
|           2 | 2018-12-10 | 20662 | 郭岩      |
|           4 | 2018-12-10 | 17016 | 张健      |
|         127 | 2018-12-10 | 17016 | 李瑞      |
+-------------+------------+-------+-----------+
65 rows in set (0.00 sec)

例如:查询部门员工人数比开发部人数少的部门

① 分析1:首先从departments表中查询开发部的编号

mysql> select dept_id from departments where dept_name='开发部';
+---------+
| dept_id |
+---------+
|       4 |
+---------+
1 row in set (0.00 sec)

② 组合:再从employees表中查询并统计开发部的员工人数

mysql> select count(*) from employees where dept_id=(-> select dept_id from departments where dept_name='开发部');
+----------+
| count(*) |
+----------+
|       55 |
+----------+
1 row in set (0.00 sec)

③ 分析2:分组查询各部门人数

mysql> select dept_id,count(*) from employees group by dept_id;
+---------+----------+
| dept_id | count(*) |
+---------+----------+
|       1 |        8 |
|       2 |        5 |
|       3 |        6 |
|       4 |       55 |
|       5 |       12 |
|       6 |        9 |
|       7 |       35 |
|       8 |        3 |
|       9 |        3 |
+---------+----------+
9 rows in set (0.00 sec)

④ 组合:查询部门员工人数比开发部人数少的部门

mysql> select dept_id,COUNT(*) from employees group by dept_id-> having count(*) < (select count(*) from employees -> WHERE dept_id=(select dept_id from departments where dept_name='开发部'));
+---------+----------+
| dept_id | COUNT(*) |
+---------+----------+
|       1 |        8 |
|       2 |        5 |
|       3 |        6 |
|       5 |       12 |
|       6 |        9 |
|       7 |       35 |
|       8 |        3 |
+---------+----------+
7 rows in set (0.00 sec)

例如:查询每个部门的人数,显示部门ID,部门名字,及人数总数(别名amount)

① 分析:查询所有部门的信息

mysql> select d.* from departments as d;
+---------+-----------+
| dept_id | dept_name |
+---------+-----------+
|       1 | 人事部    |
|       2 | 财务部    |
|       3 | 运维部    |
|       4 | 开发部    |
|       5 | 测试部    |
|       6 | 市场部    |
|       7 | 销售部    |
|       8 | 法务部    |
|       9 | NULL      |
+---------+-----------+
9 rows in set (0.00 sec)

② 组合:查询每个部门的人数

mysql> select d.*, (->  select count(*) from employees as e->  where d.dept_id=e.dept_id-> ) as amount-> from departments as d;
+---------+-----------+--------+
| dept_id | dept_name | amount |
+---------+-----------+--------+
|       1 | 人事部    |      8 |
|       2 | 财务部    |      5 |
|       3 | 运维部    |      6 |
|       4 | 开发部    |     55 |
|       5 | 测试部    |     12 |
|       6 | 市场部    |      9 |
|       7 | 销售部    |     35 |
|       8 | 法务部    |      3 |
|       9 | NULL      |      0 |
+---------+-----------+--------+
9 rows in set (0.00 sec)

扩展:通过内连接,实现查询每个部门的人数(结果相同)

mysql> select d.dept_id,d.dept_name,count(*) from employees e-> inner join departments d-> on e.dept_id = d.dept_id-> group by dept_id ;

2)多行多列

例如:查询人事部和财务部员工信息

方法1:

① 分析:查询人事部和财务部部门编号

mysql> select dept_id from departments where dept_name='人事部';
mysql> select dept_id from departments where dept_name='财务部';

② 组合:查询部门编号是两个部门编号的员工信息

mysql> select employee_id,name from employees-> where dept_id=(select dept_id from departments where dept_name='人事部') or-> dept_id=(select dept_id from departments where dept_name='财务部');

- 方法2:

① 分析:查询人事部和财务部部门编号

mysql> select dept_id from departments where dept_name in ('人事部','财务部');
+---------+
| dept_id |
+---------+
|       1 |
|       2 |
+---------+
2 rows in set (0.00 sec)

② 组合:查询部门编号是两个部门编号的员工信息

mysql> select employee_id,name from employees-> where dept_id in (select dept_id from departments where dept_name in ('人事部','财务部'));
+-------------+-----------+
| employee_id | name      |
+-------------+-----------+
|           1 | 梁伟      |
|           2 | 郭岩      |
|           3 | 李玉英    |
|           4 | 张健      |
|           5 | 郑静      |
|           6 | 牛建军    |
|           7 | 刘斌      |
|           8 | 汪云      |
|           9 | 张建平    |
|          10 | 郭娟      |
|          11 | 郭兰英    |
|          12 | 王英      |
|          13 | 王楠      |
+-------------+-----------+
13 rows in set (0.00 sec)

例如:查询人事部2018年12月所有员工工资

① 分析:查询人事部部门编号

mysql> select dept_id from departments where dept_name='人事部';
+---------+
| dept_id |
+---------+
|       1 |
+---------+
1 row in set (0.00 sec)

② 分析:查询人事部人员的编号

mysql> select employee_id from employees-> where dept_id=(select dept_id from departments where dept_name='人事部');
+-------------+
| employee_id |
+-------------+
|           1 |
|           2 |
|           3 |
|           4 |
|           5 |
|           6 |
|           7 |
|           8 |
+-------------+
8 rows in set (0.00 sec)

③ 组合:查询人事部所有员工2018年12月的工资

mysql> select * from salary-> where year(date)=2018 and month(date)=12 and employee_id in (-> select employee_id from employees-> where dept_id=(select dept_id from departments where dept_name='人事部')-> );
+------+------------+-------------+-------+-------+
| id   | date       | employee_id | basic | bonus |
+------+------------+-------------+-------+-------+
| 6252 | 2018-12-10 |           1 | 17016 |  7000 |
| 6253 | 2018-12-10 |           2 | 20662 |  9000 |
| 6254 | 2018-12-10 |           3 |  9724 |  8000 |
| 6255 | 2018-12-10 |           4 | 17016 |  2000 |
| 6256 | 2018-12-10 |           5 | 17016 |  3000 |
| 6257 | 2018-12-10 |           6 | 17016 |  1000 |
| 6258 | 2018-12-10 |           7 | 23093 |  4000 |
| 6259 | 2018-12-10 |           8 | 23093 |  2000 |
+------+------------+-------------+-------+-------+
8 rows in set (0.00 sec)

扩展:通过内连接,查询人事部2018年12月所有员工工资

mysql> select date,name,basic from salary as s-> inner join employees as e-> on s.employee_id = e.employee_id-> WHERE year(date)=2018 AND MONTH(date)=12 AND s.employee_id in(-> select employee_id from employees where dept_id=(select dept_id from departments where dept_name='人事部')-> );
+------------+-----------+-------+
| date       | name      | basic |
+------------+-----------+-------+
| 2018-12-10 | 梁伟      | 17016 |
| 2018-12-10 | 郭岩      | 20662 |
| 2018-12-10 | 李玉英    |  9724 |
| 2018-12-10 | 张健      | 17016 |
| 2018-12-10 | 郑静      | 17016 |
| 2018-12-10 | 牛建军    | 17016 |
| 2018-12-10 | 刘斌      | 23093 |
| 2018-12-10 | 汪云      | 23093 |
+------------+-----------+-------+
8 rows in set (0.00 sec)

3)单行多列

例如:查找2018年12月基本工资和奖金都是最高的工资信息

① 分析:查询2018年12月最高的基本工资

mysql> select max(basic) from salary-> where year(date)=2018 and month(date)=12;
+------------+
| max(basic) |
+------------+
|      25524 |
+------------+
1 row in set (0.00 sec)

② 分析:查询2018年12月最高的奖金

mysql> select max(bonus) from salary-> where year(date)=2018 and month(date)=12;
+------------+
| max(bonus) |
+------------+
|      11000 |
+------------+
1 row in set (0.00 sec)

③ 组合:查找2018年12月基本工资和奖金都是最高的工资信息

mysql> select * from salary-> where year(date)=2018 and month(date)=12-> and basic = (select max(basic) from salary where year(date)=2018 and month(date)=12)-> and bonus = (select max(bonus) from salary where year(date)=2018 and month(date)=12);
+------+------------+-------------+-------+-------+
| id   | date       | employee_id | basic | bonus |
+------+------------+-------------+-------+-------+
| 6368 | 2018-12-10 |         117 | 25524 | 11000 |
+------+------------+-------------+-------+-------+
1 row in set (0.01 sec)

4)多行多列

例如:查询3号部门及其部门内员工的编号、名字和email

① 分析:使用内连接,查询3号部门和员工的所有信息

mysql> select d.dept_name, e.* from departments as d-> inner join employees as e-> on d.dept_id=e.dept_id;

② 分析:将上述结果当成一张临时表,必须为其起别名。再从该临时表中查询

mysql> select dept_id, dept_name, employee_id, name, email-> from (-> select d.dept_name, e.* from departments as d-> inner join employees as e-> on d.dept_id=e.dept_id ) as tmp_table-> where dept_id=3;
+---------+-----------+-------------+-----------+--------------------+
| dept_id | dept_name | employee_id | name      | email              |
+---------+-----------+-------------+-----------+--------------------+
|       3 | 运维部    |          14 | 廖娜      | liaona@tarena.com  |
|       3 | 运维部    |          15 | 窦红梅    | douhongmei@tedu.cn |
|       3 | 运维部    |          16 | 聂想      | niexiang@tedu.cn   |
|       3 | 运维部    |          17 | 陈阳      | chenyang@tedu.cn   |
|       3 | 运维部    |          18 | 戴璐      | dailu@tedu.cn      |
|       3 | 运维部    |          19 | 陈斌      | chenbin@tarena.com |
+---------+-----------+-------------+-----------+--------------------+
6 rows in set (0.00 sec)

扩展:直接使用内连接,增加where条件判断实现如上案例

mysql> select employee_id,name,email,dept_name from employees e-> inner join departments d-> on e.dept_id = d.dept_id-> where e.dept_id=3;
+-------------+-----------+--------------------+-----------+
| employee_id | name      | email              | dept_name |
+-------------+-----------+--------------------+-----------+
|          14 | 廖娜      | liaona@tarena.com  | 运维部    |
|          15 | 窦红梅    | douhongmei@tedu.cn | 运维部    |
|          16 | 聂想      | niexiang@tedu.cn   | 运维部    |
|          17 | 陈阳      | chenyang@tedu.cn   | 运维部    |
|          18 | 戴璐      | dailu@tedu.cn      | 运维部    |
|          19 | 陈斌      | chenbin@tarena.com | 运维部    |
+-------------+-----------+--------------------+-----------+
6 rows in set (0.00 sec)

二、分页查询

使用SELECT查询时,当结果集数据量很大,比如几万行数据,放在一个页面显示的话数据量太大,若通过分页显示,每次显示100条,可减缓阅读数据压力;要实现分页功能,实际上就是从结果集中显示第1至100条记录作为第1页,显示第101至200条记录作为第2页,以此类推;

  • 分页:从结果集中“截取”出第M至N条记录。这个查询可以通过`LIMIT , 子句实现;
  • 起始索引从0开始;
  • 每页显示内容速算:`LIMIT (PAGE-1)*SIZE, SIZE`;

例如:按employee_id升序排序,取出前5位员姓名

mysql> select employee_id,name from employees-> order by employee_id-> LIMIT 0,5;
+-------------+-----------+
| employee_id | name      |
+-------------+-----------+
|           1 | 梁伟      |
|           2 | 郭岩      |
|           3 | 李玉英    |
|           4 | 张健      |
|           5 | 郑静      |
+-------------+-----------+
5 rows in set (0.00 sec)

例如:按employee_id升序排序,取出6号至8号员姓名

mysql> select employee_id,name from employees-> order by employee_id-> LIMIT 5,3;
+-------------+-----------+
| employee_id | name      |
+-------------+-----------+
|           6 | 牛建军    |
|           7 | 刘斌      |
|           8 | 汪云      |
+-------------+-----------+
3 rows in set (0.00 sec)

三、联合查询UNION(相当于全外连接)

作用:将多条select语句的结果,合并到一起,称之为联合操作。

语法:( ) UNION ( );

要求查询时,多个select语句的检索到的字段数量必须一致

每一条记录的各字段类型和顺序最好是一致的

UNION关键字默认去重,可以使用UNION ALL包含重复项

例如:

mysql> (select 'yes') union (select 'yes');
+-----+
| yes |
+-----+
| yes |
+-----+
1 row in set (0.00 sec)mysql> (select 'yes') union all (select 'yes');
+-----+
| yes |
+-----+
| yes |
| yes |
+-----+
2 rows in set (0.00 sec)

例如:查询1972年前或2000年出生的员工(两种方法,查询结果数量相同)

- 普通方法:(过滤)

mysql> select name,birth_date from employees
-> where year(birth_date)<1972 or year(birth_date)=2000;

- 联合查询方法:(拼接)

mysql> (select name,birth_date from employees where year(birth_date)<1972) UNION
-> (select name,birth_date from employees where year(birth_date)=2000);

四、插入语句

1、不指定字段名的插入

  • 格式:INSERT INTO VALUES (值1, 值2,....);
  • 格式:INSERT INTO VALUES (值1, 值2,....) , (值1, 值2,....) ...;
  • 支持多行VALUES插入

注意事项:

① 需要为所有的字段指定值;

② 值的顺序必须与表中字段的顺序一致;

③ 字符类型的字段,要用引号 “ ” 括起来;

例如:给departments表中插入VALUES值(dept_id,dept_name)

mysql> insert into departments values(10, '行政部');
Query OK, 1 row affected (0.01 sec)

常见报错:表中已有dept_id为1号部门,再插入则出错(dept_id是主键,不允许重复)

mysql> insert into departments values(1, '行政部');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

例如:给employees表中插入VALUES值(employee_id,name,hire_date,birth_date,email,phone_number,dept_id)

mysql> insert into employees values-> (134, '张三', '2019-5-10', '2000-10-12', 'zhangsan@tedu.cn', '15088772354', 9),-> (135, '李四', '2020-8-20', '1999-6-23', 'lisi@tedu.cn', '13323458734', 9);
Query OK, 2 rows affected (0.01 sec)
Records: 2  Duplicates: 0  Warnings: 0

2、指定字段名的插入

  • 格式:INSERT INTO (字段1,字段2,...) VALUES (值1,值2,....);
  • 格式:INSERT INTO (字段1,字段2,...) VALUES (值1,值2,....) , (值1,值2,....);
  • 若设置主键是自动增长的,可以不指定主键的值
  • 支持子查询插入

注意事项:

① 字段和值的顺序要一致(字段1,字段2)-->(值1,值2)

② 字段名先后顺序不重要

③ 没有赋值的字段使用默认值或自增长赋值

例如:给departments表中插入VALUES值(dept_id,dept_name),字段先后顺序不重要

mysql> insert into departments (dept_name, dept_id) values ('售后部', 11);
Query OK, 1 row affected (0.00 sec)

例如:主键由于是自动增长的【auto_increment】,可以不指定主键的值

mysql> desc departments;
+-----------+-------------+------+-----+---------+----------------+
| Field     | Type        | Null | Key | Default | Extra          |
+-----------+-------------+------+-----+---------+----------------+
| dept_id   | int(4)      | NO   | PRI | NULL    | auto_increment |
| dept_name | varchar(10) | YES  |     | NULL    |                |
+-----------+-------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)mysql> insert into departments (dept_name) values ('咨询部');
Query OK, 1 row affected (0.00 sec)

例如:支持子查询插入

mysql> insert into employees-> (name,hire_date,birth_date,email,phone_number,dept_id)-> (-> select name,hire_date,birth_date,email,phone_number,dept_id from employees-> where name='张三'-> );
Query OK, 1 row affected (0.00 sec)
Records: 1  Duplicates: 0  Warnings: 0

  

3、使用Set语句

  • 格式:INSERT INTO SET 字段名1=字段值1, 字段名2=字段值2, ...;

例如:

mysql> insert into departments set dept_name='采购部';   //dept_id自动递增
Query OK, 1 row affected (0.00 sec)
mysql> select * from departments;
+---------+-----------+
| dept_id | dept_name |
+---------+-----------+
|       1 | 人事部    |
|       2 | 财务部    |
|       3 | 运维部    |
|       4 | 开发部    |
|       5 | 测试部    |
|       6 | 市场部    |
|       7 | 销售部    |
|       8 | 法务部    |
|       9 | Null     |
|      10 | 行政部    |
|      11 | 售后部    |
|      12 | 咨询部    |
|      13 | 采购部    |
+---------+-----------+
13 rows in set (0.00 sec)

五、修改语句

1、修改单表记录

  • 格式:UPDATE SET 字段名1=字段值1, 字段名2=字段值2, ... WHERE 筛选条件;

注意事项:

- 字段值要与字段类型相匹配;

- 对于字符类型的字段,值要用双引号“”括起来;

- 若不使用where限定条件,会更新所有记录字段值;

- 限定条件时,只更新匹配条件的记录的字段值;

例如:修改人事部的名称为人力资源部

mysql> update departments set dept_name='人力资源部'-> where dept_name='人事部';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

2、修改多表连接记录

  • 格式:

UPDATE 表1 AS 表1别名

INNER | LEFT | RIGHT JOIN 表2 AS 表2别名

ON 连接条件

SET 字段名1=字段值1, 字段名2=字段值2, ...

WHERE 连接条件;

例如:修改李四所在部门为企划部

mysql> update departments as d-> inner join employees as e-> on d.dept_id=e.dept_id-> set d.dept_name='企划部'-> where e.name='李四';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0
mysql> select * from departments;
+---------+-----------+
| dept_id | dept_name |
+---------+-----------+
|       1 | 人事部    |
|       2 | 财务部    |
|       3 | 运维部    |
|       4 | 开发部    |
|       5 | 测试部    |
|       6 | 市场部    |
|       7 | 销售部    |
|       8 | 法务部    |
|       9 | 企划部    |
|      10 | 行政部    |
|      11 | 售后部    |
|      12 | 咨询部    |
|      13 | 采购部    |
+---------+-----------+
13 rows in set (0.00 sec)

六、删除记录

1、删除单表记录

  • 格式:DELETE FROM WHERE 筛选条件;

删除的是满足条件的整行记录,而不是某个字段;

注意事项:不加条件删除表中的所有行;

例如:删除重复的员工张三,只保留一个张三的信息

mysql> select * from employees where name='张三';
+-------------+--------+------------+------------+------------------+--------------+---------+
| employee_id | name   | hire_date  | birth_date | email            | phone_number | dept_id |
+-------------+--------+------------+------------+------------------+--------------+---------+
|         134 | 张三   | 2019-05-10 | 2000-10-12 | zhangsan@tedu.cn | 15088772354  |       9 |
|         136 | 张三   | 2019-05-10 | 2000-10-12 | zhangsan@tedu.cn | 15088772354  |       9 |
+-------------+--------+------------+------------+------------------+--------------+---------+
2 rows in set (0.00 sec)
mysql> delete from employees where employee_id=136;
Query OK, 1 row affected (0.00 sec)

2、删除多表记录

  • 格式:

DELETE 表1别名, 表2别名

FROM 表1 AS 表1别名

INNER | LEFT | RIGHT JOIN 表2 AS 表2别名

ON 连接条件

WHERE 筛选条件;

例如:删除9号部门中所有的员工

mysql> delete e-> from employees as e-> inner join departments as d-> on e.dept_id = d.dept_id-> where d.dept_id = 9;
Query OK, 2 rows affected (0.00 sec)

3、清空表的表记录

  • 格式:TRUNCATE TABLE 表名;

- TRUNCATE不支持WHERE条件

- 自增长列,TRUNCATE后从1开始;DELETE继续编号

- TRUNCATE不能回滚,DELETE可以

- 效率略高于DELETE

例如:清空wage_grade表

mysql> truncate table wage_grade;
Query OK, 0 rows affected (0.01 sec)

补充:drop,delete 与 truncate 的区别?

1.TRUNCATE 和 DELETE 只删除数据,而 DROP 则删除整个表(结构和数据)。

2. DELETE 删除操作作为事务记录在日志中保存以便进行进行回滚操作。

3. TRUNCATE TABLE 则一次性地从表中删除所有的数据并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。

4. 表和索引所占空间。当表被 TRUNCATE 后,这个表和索引所占用的空间会恢复到初始大小,而 DELETE 操作不会减少表或索引所占用的空间。drop 语句将表所占用的空间全释放掉。

思维导图:

小结:

本篇章节为【第四阶段】RDBMS1-DAY3 的学习笔记,这篇笔记可以初步了解到 子查询(单行单列、多行单列、单行多列、多行多列)、分页查询limit、联合查询union、插入语句、修改语句、删除语句。


Tip:毕竟两个人的智慧大于一个人的智慧,如果你不理解本章节的内容或需要相关笔记、视频,可私信小安,请不要害羞和回避,可以向他人请教,花点时间直到你真正的理解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/55474.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《OpenCV》—— 指纹验证

用两张指纹图片中的其中一张对其验证 完整代码 import cv2def cv_show(name, img):cv2.imshow(name, img)cv2.waitKey(0)def verification(src, model):sift cv2.SIFT_create()kp1, des1 sift.detectAndCompute(src, None)kp2, des2 sift.detectAndCompute(model, None)fl…

stm32四足机器人(标准库)

项目技术要求 PWM波形的学习 参考文章stm32 TIM输出比较(PWM驱动LED呼吸灯&&PWM驱动舵机&&PWM驱动直流电机)_ttl pwm 驱动激光头区别-CSDN博客 舵机的学习 参考文章 stm32 TIM输出比较(PWM驱动LED呼吸灯&&PWM驱动舵机&&PWM驱动直流电机)…

Pikichu-xss实验案例-通过xss获取cookie

原理图&#xff1a; pikachu提供了一个pkxss后台&#xff1b; 该后台可以把获得的cookie信息显示出来&#xff1b; 查看后端代码cookie.php&#xff1a;就是获取cookie信息&#xff0c;保存起来&#xff0c;然后重定向跳转到目标页面&#xff1b;修改最后从定向的ip&#xff0…

V3D——从单一图像生成 3D 物体

导言 论文地址&#xff1a;https://arxiv.org/abs/2403.06738 源码地址&#xff1a;https://github.com/heheyas/V3D.git 人工智能的最新进展使得自动生成 3D 内容的技术成为可能。虽然这一领域取得了重大进展&#xff0c;但目前的方法仍面临一些挑战。有些方法速度较慢&…

Scrapy 爬虫的大模型支持

使用 Scrapy 时&#xff0c;你可以轻松使用大型语言模型 (LLM) 来自动化或增强你的 Web 解析。 有多种使用 LLM 来帮助进行 Web 抓取的方法。在本指南中&#xff0c;我们将在每个页面上调用一个 LLM&#xff0c;从中抽取我们定义的一组属性&#xff0c;而无需编写任何选择器或…

【ZYNQ 开发】填坑!双核数据采集系统LWIP TCP发送,运行一段时间不再发送且无法ping通的问题解决

问题描述 之所以说是填坑&#xff0c;是因为之前写了一篇关于这个双核数据采集系统的调试记录&#xff0c;问题的具体表现是系统会在运行一段时间后&#xff08;随机不定时&#xff0c;长了可能将近两小时&#xff0c;短则几分钟&#xff09;&#xff0c;突然间就不向电脑发送数…

windows下安装rabbitMQ并开通管理界面和允许远程访问

如题&#xff0c;在windows下安装一个rabbitMQ server&#xff1b;然后用浏览器访问其管理界面&#xff1b;由于rabbitMQ的默认账号guest默认只能本机访问&#xff0c;因此需要设置允许其他机器远程访问。这跟mysql的思路很像&#xff0c;默认只能本地访问&#xff0c;要远程访…

Web和UE5像素流送、通信教程

一、web端配置 首先打开Github地址&#xff1a;https://github.com/EpicGamesExt/PixelStreamingInfrastructure 找到自己虚幻引擎对应版本的项目并下载下来&#xff0c;我这里用的是5.3。 打开项目找到PixelStreamingInfrastructure-master > Frontend > implementat…

Redis介绍及整合Spring

目录 Redis介绍 Spring与Redis集成 Redis介绍 Redis是内存数据库&#xff0c;Key-value型NOSQL数据库&#xff0c;项目上经常将一些不经常变化并且反复查询的数据放入Redis缓存&#xff0c;由于数据放在内存中&#xff0c;所以查询、维护的速度远远快于硬盘方式操作数据&#…

启动服务并登录MySQL9数据库

【图书推荐】《MySQL 9从入门到性能优化&#xff08;视频教学版&#xff09;》-CSDN博客 《MySQL 9从入门到性能优化&#xff08;视频教学版&#xff09;&#xff08;数据库技术丛书&#xff09;》(王英英)【摘要 书评 试读】- 京东图书 (jd.com) Windows平台下安装与配置MyS…

Llama3.2开源:Meta发布1B和3B端侧模型、11B和90B多模态模型

最近这一两周不少互联网公司都已经开始秋招提前批面试了。 不同以往的是&#xff0c;当前职场环境已不再是那个双向奔赴时代了。求职者在变多&#xff0c;HC 在变少&#xff0c;岗位要求还更高了。 最近&#xff0c;我们又陆续整理了很多大厂的面试题&#xff0c;帮助一些球友…

大数据毕业设计选题推荐-民族服饰数据分析系统-Python数据可视化-Hive-Hadoop-Spark

✨作者主页&#xff1a;IT研究室✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

栏目二:Echart绘制动态折线图+柱状图

栏目二&#xff1a;Echart绘制动态折线图柱状图 配置了一个ECharts图表&#xff0c;该图表集成了数据区域缩放、双Y轴显示及多种图表类型&#xff08;折线图、柱状图、象形柱图&#xff09;。图表通过X轴数据展示&#xff0c;支持平滑折线展示比率数据并自动添加百分比标识&…

Docker-2.如何保存数据退出

在使用Docker时&#xff0c;我们常常需要修改容器中的文件&#xff0c;并且希望在容器重启后这些修改能够得到保留。 0.简介 使用Docker时有一个需要注意的问题&#xff1a;当你修改了容器中的文件后&#xff0c;重启容器后这些修改将会被重置&#xff0c;深入研究这个问题。 …

企业间图文档发放:如何在保障安全的同时提升效率?

不管是大型企业&#xff0c;还是小型创业公司&#xff0c;不论企业规模大小&#xff0c;每天都会有大量的图文档发放&#xff0c;对内传输协作和对外发送使用&#xff0c;数据的生产也是企业业务生产力的体现之一。 伴随着业务范围的不断扩大&#xff0c;企业与客户、合作伙伴之…

五子棋双人对战项目(2)——登录模块

目录 一、数据库模块 1、创建数据库 2、使用MyBatis连接并操作数据库 编写后端数据库代码 二、约定前后端交互接口 三、后端代码编写 文件路径如下&#xff1a; UserAPI&#xff1a; UserMapper&#xff1a; 四、前端代码 登录页面 login.html&#xff1a; 注册页面…

ireport 5.1 中文生辟字显示不出来,生成PDF报字体找不到

ireport生成pdf里文字不显示。本文以宋体中文字不显示为例。 问题&#xff1a;由浅入深一步一步分析 问题1、预览正常&#xff0c;但生成pdf中文不显示 报告模板编辑后&#xff0c;预览正常&#xff0c;但生成pdf中文不显示。以下是试验过程&#xff1a; 先编辑好一个报告单模…

在 Docker 版 RStudio 中安装 Seurat V4 的完整教程 (同样适用于普通R环境安装)

在单细胞RNA测序&#xff08;scRNA-seq&#xff09;数据分析领域&#xff0c;Seurat 是一个广泛使用且功能强大的R包&#xff0c;提供了丰富的数据处理和可视化工具。为了简化环境配置和依赖管理&#xff0c;使用Docker来部署RStudio并安装Seurat V4是一种高效且可重复的方法。…

华硕天选笔记本外接音箱没有声音

系列文章目录 文章目录 系列文章目录一.前言二.解决方法第一种方法第二种方法 一.前言 华硕天选笔记本外接音箱没有声音&#xff0c;在插上外接音箱时&#xff0c;系统会自动弹出下图窗口 二.解决方法 第一种方法 在我的电脑上选择 Headphone Speaker Out Headset 这三个选项…

一文上手SpringSecurity【八】

RBAC&#xff08;Role-Based Access Control&#xff09;&#xff0c;基于角色的访问控制。通过用户关联角色&#xff0c;角色关联权限&#xff0c;来间接的为用户赋予权限。 一、RBAC介绍 RBAC&#xff08;Role-Based Access Control&#xff09;&#xff0c;即基于角色的访…