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.mzph.cn/diannao/64366.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mybatisplus的学习

一、条件查询部分 在引入mybatisplus的依赖以后,我们不需要再引入mybatis的依赖,因为mybatisplus中已经包含mybatis的依赖。 1自动映射规则 变量名称:private String name 属性名:public String getName(){return name; } 这个getName 中的name就是属性名称 表名和实…

jenkins+docker部署springboot+vue项目

后端的Dockerfile和docker启动脚本 FROM openjdk:17COPY . /home/ProjectSpace/cli/extranet/serverCOPY simsun.ttf /usr/share/fonts/chinese/simsun.ttfWORKDIR /home/ProjectSpace/cli/extranet/serverCMD java -Dspring.config.location/home/ProjectSpace/cli/extranet/…

opencv-python的简单练习

题目1.读取一张彩色图像并将其转换为灰度图。 import cv2 # 读取图片文件 img cv2.imread(./1.png)# 将原图灰度化 img_gray cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)# 输出图片 cv2.imshow(img,img) cv2.imshow(img_g,img_gray) # 进行阻塞 cv2.waitKey(0) 题目2&#xff1a;…

AOP实现操作日志记录+SQL优化器升级

文章目录 1.引入依赖1.sun-dependencies 指定依赖2.将sun-dependencies进行install3.sun-common-log引入依赖 2.sun-common-log代码实现1.LogAspect.java&#xff08;需要更改包时就修改Pointcut的切点表达式即可&#xff09;2.log4j2-spring.xml3.效果展示 3.SQL优化器升级1.目…

CH582F BLE5.3 蓝牙核心板开发板 60MHz RAM:32KB ROM:448KB

CH582F BLE5.3 蓝牙核心板开发板 60MHz RAM:32KB ROM:448KB 是一款基于南京沁恒&#xff08;WCH&#xff09;推出的高性能、低功耗无线通信芯片CH582F的开发板。以下是该开发板的功能和参数详细介绍&#xff1a; 主要特性 双模蓝牙支持&#xff1a; 支持蓝牙5.0标准&#xff0…

AI技术在演示文稿制作中的应用一键生成PPT

在快节奏的现代工作环境中&#xff0c;时间就是金钱。为了提高工作效率&#xff0c;许多专业人士都在寻找能够快速生成演示文稿&#xff08;PPT&#xff09;的工具。本文将探讨AI技术如何帮助用户自动生成演示文稿&#xff0c;从文案撰写到排版&#xff0c;最终输出成品&#x…

【Redis篇】Set和Zset 有序集合基本使用

目录 Set 基本命令 sadd SMEMBERS SISMEMBER SCARD 返回值&#xff1a; SPOP SMOVE SREM 集合间操作 交集&#xff1a; 并集&#xff1a; 差集&#xff1a; ​编辑 内部编码 使用场景&#xff1a; Zset 有序集合 Zset基本命令 ZADD ZCARD ZCOUNT ZRANGE …

OpenCV相机标定与3D重建(25)计算两个三维点集之间的最优仿射变换矩阵(3x4)函数estimateAffine3D()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 计算两个3D点集之间的最优仿射变换。 它计算 [ x y z ] [ a 11 a 12 a 13 a 21 a 22 a 23 a 31 a 32 a 33 ] [ X Y Z ] [ b 1 b 2 b 3 ] \beg…

安防监控Liveweb视频汇聚融合平台助力执法记录仪高效使用

Liveweb平台可接入的设备除了常见的智能分析网关与摄像头以外 &#xff0c;还可通过GB28181协议接入执法记录仪&#xff0c;实现对执法过程的全程监控与录像&#xff0c;并对执法轨迹与路径进行调阅回看。那么&#xff0c;如何做到执法记录仪高效使用呢&#xff1f; 由于执法记…

技术理性角度思考:游戏是什么?

1、从单纯技术理性角度来看&#xff0c;游戏就是若干事件的组合&#xff0c; 每一个事件都是若干代码控制的若干动画。通过各种事件&#xff0c;玩家持续输入&#xff0c;改变游戏状态&#xff0c;获得输出结果。 细分为界面切换事件&#xff0c;游戏逻辑事件&#xff0c; a…

Jenkins 编写Pipeline 简介及使用初识详解

一、Jenkins Pipeline简介 Jenkins Pipeline是Jenkins的一个重要功能,Jenkins 2.0 以上才会有,一系列 Jenkins 插件将整个持续集成用解释性代码 Jenkinsfile 来描述,它允许开发者以代码的方式定义整个持续集成和交付(CI/CD)流程,包括构建、测试、部署和监控等步骤。Jenk…

构建一个rust生产应用读书笔记四(实战1)

我们需要从访客那里收集哪些信息&#xff0c;以便将其登记为电子邮件通讯的订阅者&#xff1f; 电子邮件地址&#xff1a;这是最基本的要求&#xff0c;因为我们需要通过电子邮件地址向订阅者发送内容。姓名&#xff1a;虽然这不是强制性的&#xff0c;但我们希望收集一个名字…

IDEA 未启用lombok插件的Bug

项目中maven已引用了lombok依赖&#xff0c;之前运行没有问题的&#xff0c;但有时启动会提示&#xff1a; java: You arent using a compiler supported by lombok, so lombok will not work and has been disabled. Your processor is: com.sun.proxy.$Proxy8 Lombok support…

【vue】npm install 报错 python2 Error: not found: python2

如图所示&#xff0c;vue项目在下载依赖的时候报错找不到python2&#xff0c;有网友通过下载python2.7并配置环境变量解决了&#xff0c;这里有两个其他自测可用的方式&#xff0c;供各位作为参考。 报错的主要原因是因为【sass-loader】【node-sass】这两个依赖跟nodejs版本有…

批量DWG文件转换低版本(CAD图转低版本)——c#插件实现

此插件可实现指定路径下所有dwg文件&#xff08;包含子文件夹内dwg&#xff09;一键全部转为低版本&#xff08;包含2004、2007、2018版本&#xff0c;也可定制指定版本&#xff09;。效果如下&#xff1a; &#xff08;使用方法&#xff1a;命令行输入 “netload” 加载插件&…

信奥题解:勾股数计算中的浮点数精度问题

来源:GESP C++ 二级模拟题 本文给出官方参考答案的详细解析,包括每一部分的功能和关键点,以及与浮点数精度相关的问题的分析。 题目描述 勾股数是很有趣的数学概念。如果三个正整数a 、b 、c ,满足 a 2 + b 2 = c 2 a^2 + b^2 = c^2 a2+b2=c2 ,而且1 ≤ a ≤ b ≤ c ,…

解决 Spring 单例 Bean 注入原型 Bean 被共享的问题

在使用 Spring 开发应用时&#xff0c;Bean 的作用域&#xff08;Scope&#xff09; 决定了 Bean 实例的生命周期。Spring 提供了多种作用域&#xff0c;其中最常见的是 单例&#xff08;singleton&#xff09; 和 原型&#xff08;prototype&#xff09; 作用域。 单例作用域…

解决 OpenCV 与 FFmpeg 版本不兼容导致的编译错误

解决 OpenCV 与 FFmpeg 版本不兼容导致的编译错误 在安装并编译 OpenCV 3.2.0 版本时&#xff0c;出现的编译错误主要是由于 OpenCV 代码中使用的 FFmpeg 库宏定义与最新版 FFmpeg 库中的定义不一致所致。具体来说&#xff0c;原有的宏 CODEC_FLAG_GLOBAL_HEADER 和 AVFMT_RAW…

剑指offer搜索二维矩阵

题目连接 https://leetcode.cn/problems/search-a-2d-matrix-ii/’ 代码 自己想出来的 解法一 初始化两个指针&#xff0c;i0,j列数-1 若此时matrix[i][j]target 则返回true 若此时matrix[i][j]>target,表明在第j列中不可能存在target&#xff0c;因为列是升序的 若此时ma…

无管理员权限 LCU auth-token、port 获取(全网首发 go)

一&#xff1a; 提要&#xff1a; 参考项目&#xff1a; https://github.com/Zzaphkiel/Seraphine 想做一个 lol 查战绩的软件&#xff0c;并且满足自己的需求&#xff08;把混子和大爹都表示出来&#xff09;&#xff0c;做的第一步就是获取 lcu token &#xff0c;网上清一色…