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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学编程就要猛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值