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(下),**本篇不方便讲。

相关推荐
麦聪聊数据4 小时前
企业数据流通与敏捷API交付实战(五):异构数据跨库联邦与零代码发布
数据库·sql·低代码·restful
Elastic 中国社区官方博客4 小时前
当 TSDS 遇到 ILM:设计不会拒绝延迟数据的时间序列数据流
大数据·运维·数据库·elasticsearch·搜索引擎·logstash
qing222222224 小时前
Linux中修改mysql数据表
linux·运维·mysql
Omics Pro4 小时前
虚拟细胞:开启HIV/AIDS治疗新纪元的关键?
大数据·数据库·人工智能·深度学习·算法·机器学习·计算机视觉
J2虾虾4 小时前
MySQL的基本操作
数据库·mysql
arvin_xiaoting5 小时前
OpenClaw学习总结_III_自动化系统_3:CronJobs详解
数据库·学习·自动化
杨云龙UP5 小时前
Oracle 中 NOMOUNT、MOUNT、OPEN 怎么理解? 在不同场景下如何操作?_20260402
linux·运维·数据库·oracle
jzwugang5 小时前
postgresql链接详解
数据库·postgresql
2601_949815335 小时前
MySQL输入密码后闪退?
数据库·mysql·adb
lifewange6 小时前
Redis的测试要点和测试方法
数据库·redis·缓存