赞
踩
今天来讲MySQL数据库的表增删查改操作。今天主要是通过栗子来演示语法使用的,话不多说,直奔主题~
表的增删查改:
CRUD : Create(创建), Retrieve(读取),Update(更新),Delete(删除)
目录
孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80
查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示
查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示
将曹孟德同学的数学成绩变更为 60 分,语文成绩变更为 70 分
delete from 和 truncate [table]
语法
insert [into] table_name[(column [, column] ...)] values (value_list) [, (value_list)] ...
创建案例:
举个栗子:
举个栗子:
由于 主键 或者 唯一键 对应的值已经存在而导致插入失败
选择同步性更新语法:
insert ... on duplicate key update column = value [, column = value] ...
举个栗子:
我们插入数据时有主键或者唯一键冲突了,我们使用on duplicate key update后,哪一个键先冲突,就更新那一行的数据内容,按照update后的内容进行更新。
-- 主键 或者 唯一键 没有冲突,则直接插入;
-- 主键 或者 唯一键 如果冲突,则删除后再插入REPLACE INTO students (sn, name) VALUES (20001, '曹阿瞒');
Query OK, 2 rows affected (0.00 sec)
-- 1 row affected: 表中没有冲突数据,数据被插入
-- 2 row affected: 表中有冲突数据,删除后重新插入
举个栗子:
多个列数据冲突时:
准备工作,创建表结构:
-- 通常情况下不建议使用 * 进行全列查询
-- 1. 查询的列越多,意味着需要传输的数据量越大,会导致数据大量刷屏,效率降低;
-- 2. 可能会影响到索引的使用。
举个栗子:
注意distinct后面跟一个列名和多个列名的情况。
关于比较运算符如下,我们下面通过场景来学习。
注意,MySQL中比较等于时,是用=来比较的,和语言中的等号是不同的。
那判断不为NULL呢?
在这里判断是否为NULL虽说不止一种写法,但是我们只要使用is noll 和is not null来判断就好了,这样降低自己的学习成本,还看起来比较主观。
逻辑运算符:
我们要注意where和order by语句的执行顺序。
where语句中不能取别名
-- 起始下标为 0
-- 从 0 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n;
-- 从 s 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n;
-- 从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;
UPDATE table_name SET column = expr [, column = expr ...] [WHERE ...] [ORDER BY ...] [LIMIT ...]
注意一个细节:
DELETE FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...]
我们使用delete from 表名删除表数据后,对于表结构是不改变的。 如auto_increment字段记录的默认值是不变的。
truncate [TABLE] table_name
举个栗子:
delete from操作会被记录在bin log日志中,而truncate操作是不会记录在bin log记录中,说明后者是不适合数据备份的。
去重操作:
注意,对于这种情况分组是排到第一步的,where使用就不合适了,因为where几乎是先执行的子句,这时候我们只能借助having来帮助我们筛选。
where和having可以一起配合使用
给博主点个赞呗~
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。