MySQL:CRUD(上)

1. CRUD概念

CRUD指的是对数据表数据的增删查改操作,C---》Create ; R---》Retrieve ; U---》Update ; D---》Delete ;CRUD可以与条件(where)配合使用,但"CRUD(上)"不讲包含条件的CRUD指令。

2. Create(新建)

2.1 语法

INSERT INTO table_name (column \[, column ...)] VALUES (value_list) , (value_list) ...
value_list: value, , value ...

2.2 插入数据 (insert)

2.2.1 指定列插入

数据类型与列不匹配会报错。

2.2.2 全列插入

其实上面的**insert into book(book_name,book_price) values...;**也是全列插入,因为指定的列已经是表中全部的列了。

当我们不在表名后指定列插入,默认为全列插入:

Insert into book values('张三列传',123);

列、值不匹配:

2.2.3 一次插入多条数据

不管是指定列插入,还是全列插入,插入多条数据的方式都一样。

我去,打错字了,应该是"大圣出世"。。。

这样的形式:values(),(),()....;

3. Retrieve(检索)

3.1 语法

这个语法看起来有点复杂,我们不必纠结,直接看下面的查询 (检索)示例,看完再回头看语法就能理解了。(使用条件的查询,也就是包含第二行开始到最后的一行,使用到条件的查询语句都不讲,在**CRUD(下)**讲)

SELECT DISTINCT select_expr , *select_expr* ... FROM *table_references*

WHERE *where_condition*

GROUP BY {*col_name* \| *expr*}, ...

HAVING *where_condition*

ORDER BY {*col_name* \| *expr*} \[ASC \| DESC\], ...

LIMIT {\[*offset*,\] *row_count* \| *row_count*OFFSET *offset*}

3.2 查询数据 (select)

3.2.1 指定列查询

select 列名1,列名2,... from 表名;

列名之间用英文逗号分隔。

3.2.2 全列查询

其实,在前面我们已经见过全列查询语法了:

select * from 表名;

* 是通配符,意为查询表中所有的列。

3.2.3 查询字段为表达式

又叫字段。查询列为表达式:

select 列名1,表达式 from 表名;

select子句中可只有表达式或同时包含表达式和列名。

查询中的表达式还可以这样:

计算总分

每人数学成绩加5分:

3.2.4 为查询结果指定别名

上面个那个计算总分的表达式查询,是不是不太美观或不太直观------》查出来的总分列列名就写着Chinese+math+english。这时我们的别名就派上用场了:

语法:

select 列名 as 别名 from 表名;

需要注意的是,当列名中有空格的话要使用英文单引号包裹,如:'总 分'。其实标准中别名都是要用单引号包裹的,但实际中不太会这样做。

3.2.5 结果去重查询

语法:

select distinct 列名1,列名2 from 表名;

应用:

注意:distinct的去重是指,查询出的数据行每列数据都相同,才会进行去重。

下面这张就不会去重,因为孙悟空与弼马温的id不同:

Update(修改)、Delete和条件等知识都在**CRUD(下),**本篇不方便讲。

相关推荐
笃行35017 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行35017 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行35017 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H17 小时前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
SelectDB2 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵2 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils2 天前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
SamDeepThinking2 天前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员