当前位置: 首页 > article >正文

Mysql学习笔记之SQL-2

上篇文章介绍了SQL语句的第一部分数据定义语言(DDL),这篇文章我们介绍SQL语句的第二部分,数据库操作语言(DML)

1.简介

DML全称(Data Manipulation Language),用来对数据表中的数据进行操作。
包括:

  • 增加数据
  • 删除数据
  • 修改数据

下面依次介绍每种操作的语法和案例。

2.增加数据

增加数据是指在数据表中插入一条或者多条数据,语法如下所示:

INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (1,2, ...);

当插入的数据为表中全部字段时可以省略字段名,如:

-- 存在student数据表,包含字段 id、name、sex、age 插入全部字段可简写如下
INSERT INTO 表名 VALUES (1,2,3,4);

这两种写法有什么区别?
当数据表中的某些字段可以为空或者存在默认值时(后面会详细说明),在增加数据时就可以给需要的字段指定值,而不需要的字段可以不设置值,这时候就需要使用第一种写法。

反之,如果当数据表中的字段都必须不能为空且不存在默认值时,在增加数据时就必须给每个字段赋值,这时第二种写法就比较简单。

案例:
写法一:
1.给student数据表中添加一条数据,要求指定全部字段

INSERT INTO student (id,name,sex,age) VALUES(7,'皮洋洋','男',20);

2 .给students数据表中添加一条数据,只指定姓名和性别
这时候就需要数据表中的字段可以为空,我们可以通过naticat的设计表功能查看当前student表格的状态
在这里插入图片描述
将id、和age字段的“不是null“复选框去掉,点击保存
在这里插入图片描述
这时执行以下语句

INSERT INTO student (name,sex) VALUES('张三丰','男');

在这里插入图片描述
未指定字段的值就为空
写法二:

INSERT INTO student VALUES(9 ,'张三丰','男',19);

一次插入多条数据

INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (1,2, ...),(1,2,...),(1,2,...)...;
-- 或者
INSERT INTO 表名 VALUES(1,2,...),(1,2,...),(1,2,...)...;

当有大量的数据需要插入时,组合成一条sql语句插入效率会大大提高
案例:

INSERT INTO `test`.`student` (`id`, `name`, `sex`, `age`) VALUES (1, '张三', '男', 16)
,(2, '李四', '男', 16)
,(3, '王五', '男', 18)
,(4, '李翠翠', '女', 16)
,(5, '王芳芳', '女', 16)
,(6, '赵琴', '女', 16)
,(7, '皮洋洋', '男', 20)
,(9, '张三丰', '男', 19);

3.删除数据

3.1删除全部数据

DELETE FROM 表名;

执行后会清空表格,慎用!!!

3.2删除指定数据

DELETE FROM 表名 WHERE 条件;

案例:
1.删除学号为1的学生

DELETE FROM student WHERE id = 1;

2.删除学号不为1的学生

DELETE FROM student WHERE id <> 1;

3.删除学号大于10的学生

DELETE FROM student WHERE id > 10;

4.删除学号为2,3,4的学生

DELETE FROM student WHERE id == 2 or id == 3 or id == 4;
--或者
DELETE FROM student WHERE id in (2,3,4);

where条件后面可以判断任意的字段,这里不一一举例了,下表列举了where条件支持的比较符

条件比较符
比较= , > , < , >= , <= , (<> , !=不等于)
确定集合IN,NOT IN
字符匹配LIKE,NOT LIKE 通配符 % ,_
逻辑运算AND, OR(, NOT
空值判断IS NULL , IS NOT NULL

4.修改数据

UPDATE 表名 SET 字段名1 =1 , 字段名2 =2 , .... [ WHERE 条件 ] ;

注意
修改数据的where条件虽然时非必须的,但当where条件不指定时更新的数据将会是整张表格
where条件的语法跟删除数据中的where条件语法一样

案例:
1.将学号为1的学生,年龄修改为20

UPDATE student SET age = 20 WHERE id = 1;

2.将学号为2的学生,名称修改为黄眉大王

UPDATE student SET name = '黄眉大王' WHERE id = 2;

2.将所有学生的年龄都改为18

UPDATE student SET age = 18;

http://www.kler.cn/a/442719.html

相关文章:

  • 大数据原生集群 (Hadoop3.X为核心) 本地测试环境搭建二
  • C# 25Dpoint
  • 如何通俗易懂的理解 html js css
  • 【Unity高级】一文了解Unity 中的条件编译(附所有指令)
  • 行业案例:高德服务单元化方案和架构实践
  • Hadoop•安装JDK
  • 剑指Offer|LCR 007. 三数之和
  • sunset: midnight
  • Elasticsearch Kibana (windows版本) 安装和启动
  • vue3-tp8-Element:对话框实现
  • TCP Analysis Flags 之 TCP Fast Retransmission
  • 【Unity功能集】TextureShop纹理工坊(二)图层(下)
  • 车辆重识别代码笔记12.18
  • JS的原型和原型链浅析
  • 深度学习中,卷积层的若干思考!!!
  • 【OSS】php使用oss存储
  • 【Elasticsearch】使用阿里云 infererence API 及 semantic text 进行向量搜索
  • 27.多态
  • DuckDB: 两种方法实现动态分组查询
  • 解决git push出现的报错:Permission denied (publickey)
  • 本地项目显示正常,打包部署后ElementUI重点饿图标全部显示异常为小方框
  • 天线覆盖方案简图
  • 云连POS-ERP管理系统ZksrService存在SQL注入漏洞
  • bug之浮点数精度求和计算
  • IntelliJ IDEA中的语言级别版本与目标字节码版本配置
  • c++数据结构算法复习基础--13--基数算法