MYSQL之增删改查(中)

news2024/11/18 3:40:51

 前言:

         以下是MySQL最基本的增删改查语句,很多IT工作者都必须要会的命令,也 是IT行业面试最常考的知识点,由于是入门级基础命令,所有所有操作都建立在单表 上,未涉及多表操作。

4、“查”——之单表查询

         MySQL从数据表中查询数据最基本的语句是SELECT语句,在前面的“增删查”已经 使用过:SELECT * FROM 表名,也就是查询指定数据表中的所有数据。下面将对 SELECT语句进行详细介绍。

在进行后面的操作之前我们先建立一个新的数据表student2,如下:

CREATE TABLE student2
(
    id INT(3) PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(20) NOT NULL,
    grade FLOAT,gender CHAR(2)
);

       此处的PRIMARY KEY表示将该字段设为主键,AUTO_INCREMENT表示将该字段设 为开始值是 1,每条新记录自动递增 1,,所以在插入数据时不需为该字段设值;NOT NULL表示将该字段限制为非空值(此处不作详细讲解)

再向student2表中插入如下数据:

        INSERT INTO student2(name,grade,gender)
        VALUES ('songjiang',40,'男'),('wuyong',100,'男'),
('qinming',90,'男'),('husanniang',88,'女'),('sunerniang',66,'女'),
('wusong',86,'男'),('linchong',92,'男'),('yanqing',90,NULL);

注意:

        若因为此处插入的数据包含了中文而导致无法插入,可将“男/女”改为“man/woman”,或 者将字段编码改为utf­8(方法自行百度,此处不做讲解)。

4.1 简单查询

4.1.1 查询所有字段

语法:SELECT 字段名1,字段名2,…
     FROM 表名
举例:查询student2表中的所有记录
命令:SELECT id,name,grade ,gender
     FROM student2;

结果:

注意:

      字段顺序可以更改,如:

SELECT id,grade,gender ,name
    FROM student2;

则显示的结果也会作出对应的调整:

4.1.2 在SELECT语句中使用(‘ * ’)通配符代替所有字段

语法:SELECT * FROM 表名;

在此前已多次使用此命令,所以此处不作赘述。

4.1.3 查询指定的部分字段

语法:SELECT 字段名1,字段名2,… FROM 表名;

举例:查询student2表中的name字段和gender字段

命令:SELECT name,gender FROM student2;

结果:

从结果中可以看到只显示了name和gender两个字段。

4.2 按条件查询

4.2.1 带关系运算符的查询

语法:SELECT 字段名1,字段名2,…

           FROM 表名

          WHERE 条件表达式

在WHERE子句中可以使用如下关系运算符:

举例:查询student2表中id为4的人的id和name字段
命令:SELECT id,name FROM student2 WHERE id=4;

结果:

举例:查询student2表中grade大于80的人的name和grade字段
命令:SELECT name FROM student2 WHERE grade>80;

结果:

4.2.2 带 IN 关键字的查询

IN关键字用于判断某个字段的值是否在指定集合中,若在,则该字段所在的记录将会被查询出来.

IN关键字用于判断某个字段的值是否在指定集合中,若在,则该字段所在的记录将会被查询出来.
语法:SELECT * | 字段名1,字段名2,…
      FROM 表名
      WHERE 字段名 [ NOT ] IN (元素1,元素2,…)
举例:查询student2表中id值为1,2,3的记录
命令:SELECT * FROM student2 WHERE id IN (1,2,3);

结果:

注意:

       NOT IN 与 IN 相反,查询的是不在指定范围内的记录。

4.2.3 带 BETWEEN AND 关键字的查询

       BETWEEN AND 用于判断某个字段的值是否在指定范围之内,若在,则该字段所在的记录会被查 询出来,反之不会。

语法:SELECT * | { 字段名1,字段名2,… }
      FROM 表名
      WHERE 字段名 [ NOT ] BETWEEN 值1 AND 值2;
举例:查询student2表中id值在2~5之间的人的id和name
命令:SELECT id,name FROM students WHERE id BETWEEN 2 AND 5;

结果:

注意:

       NOT BETWEEN AND 表示查询指定范围外的记录。

4.2.4 空值查询

         在数据表中有些值可能为空值(NULL),空值不同于0,也不同于空字符串,需要使用 IS NULL 来判断字段的值是否为空值。

语法:SELECT * | 字段名1,字段名2,…
      FROM 表名
      WHERE 字段名 IS [ NOT ] NULL
举例:查询student2表中gender值为空值的记录。
命令:SELECT * FROM student2 WHERE gender IS NULL;

结果:

注意:

        IS NOT NULL 关键字用来查询字段不为空值的记录。

4.2.5 带 DISTINCT 关键字的查询

       很多表中某些字段的数据存在重复的值,可以使用DISTINCT关键字来过滤重复的值,只保留一个 值。

语法:SELECT DISTINCT 字段名 FROM 表名;
举例:查询student2表中gender字段的值,结果中不允许出行重复的值。
命令:SELECT DISTINCT gender FROM student2;

结果:

注意:

        DISTINCT 关键字还可作用于多个字段,则只有多个字段的值都完全相同时才会被认作是 重复记录。

4.2.6 带 LIKE 关键字的查询

语法:SELECT * | 字段名1,字段名2,…
      FROM 表名
      WHERE 字段名 [ NOT ] LIKE ‘匹配字符串’;
(1)百分号(%)通配符

        匹配任意长度的字符串,包括空字符串。例如,字符串“ c% ”匹配以字符 c 开始,任意长度的字 符串,如“ ct ”,“ cut ”,“ current ”等;字符串“ c%g ”表示以字符 c 开始,以 g 结尾的字符 串;字符串“ %y% ”表示包含字符“ y ”的字符串,无论“ y ”在字符串的什么位置。 举例1:查询student2表中name字段以字符“ s ”开头的人的id,name

命令:SELECT id,name FROM student2 WHERE name LIKE "S%";

结果:

举例2:查询student2表中name字段以字符“ w ”开始,以字符“ g ”结尾的人的id,name。
命令:SELECT id,name FROM student2 WHERE name LIKE 'w%g';

结果:

举例3:查询student2表中name字段不包含“ y ”的人的id,name。
命令:SELECT id,name FROM student2 WHERE name NOT LIKE '%y%';

结果:

(2)下划线(_)通配符

        下划线通配符只匹配单个字符,若要匹配多个字符,需要使用多个下划线通配符。例如,字符串“ cu_ ”匹配以字符串“ cu ”开始,长度为3的字符,如“ cut ”,“ cup ”;字符串“ c__l”匹配在“ c ”和“ l ”之间包含两个字符的字符串,如“ cool ”。需要注意的是,连续的“_”之间不能有空格,例 如“M_ _QL”只能匹配“My SQL”,不能匹配“MySQL”。  

举例:查询在student2表中name字段值以“ wu ”开始,以“ ong ”结束,并且中间只有一个字符的记录。
命令:SELECT * FROM student2 WHERE name LIKE 'wu_ong';

结果:

注意:

         若要查询的字段值本来就含有“ % ”或者“ _ ”,则要用“ \ ”进行转义,如要查询本身含有“ % ”的字符串,命令应改为 “ %\%%”。

4.2.7 带 AND 关键字的多条件查询

        在使用SELECT语句查询数据时,优势为了使查询结果更加精确,可以使用多个查询条件,如使用 AND 关键字可以连接两个或多个查询条件。

语法:SELECT * | 字段名1,字段名2,…
      FROM 表名
      WHERE 条件表达式1 AND 条件表达式2 [ … AND 条件表达式 n ];
举例:查询student2表中 id 字段小于5,并且 gender 字段值为“ 女 ”的人的id和name
命令:SELECT id,name FROM student2 WHERE id<5 AND gender='女';

结果:

4.2.8 带 OR 关键字的多条件查询

        与 AND 关键字不同,OR 关键字只要满足任意一个条件就会被查询出来

语法:SELECT * | 字段名1,字段名2,…
      FROM 表名
      WHERE 条件表达式1 OR 条件表达式2 [ … OR 条件表达式 n ];
举例:查询student2表中 id 字段小于3,或者 gender 字段值为“ 女 ”的人的id,name和gender
命令:SELECT id,name ,gender FROM student2 WHERE id<3 OR gender='女';

结果:

4.2.9 OR 和 AND 一起使用的情况

        OR 和 AND 一起使用的时候,AND 的优先级高于 OR,因此二者一起使用时,会先运算 AND 两 边的表达式,再运算 OR 两边的表达式。

举例:查询student2表中gender值为“女”或者gender值为“男”并且grade字段值为100的人的记录
命令:SELECT * FROM student2 WHERE gender='女' OR gender='男' AND grade=100;

结果:

---------------------------------未完待续,请看下篇--------------------------

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1610640.html

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

相关文章

Linux的firewalld防火墙

介绍firewalld&#xff1a; ①、firewalld&#xff08;Dynamic Firewall Manager of Linux systems&#xff0c;Linux系统的动态防火墙管理器&#xff09;服务是默认的防火墙配置管理工具&#xff0c;它拥有基于CLI&#xff08;命令行界面&#xff09;和基于GUI&#xff08;图…

专业清洁工匠服务网站模板 html网站

目录 一.前言 二.页面展示 三.下载链接 一.前言 该HTML代码生成了一个网页&#xff0c;包括以下内容&#xff1a; 头部信息&#xff1a;指定了网页的基本设置和元数据&#xff0c;例如字符编码、视口大小等。CSS文件&#xff1a;引入了多个CSS文件&#xff0c;用于设置网页…

程序员自由创业周记#32:新产品构思

程序员自由创业周记#32&#xff1a;新产品构思 新作品 我时常把自己看做一位木匠&#xff0c;有点手艺&#xff0c;能做一些作品养活自己。而 加一、Island Widgets、Nap 就是我的作品。 接下来在持续维护迭代的同时&#xff0c;要开启下一个作品的创造了。 其实早在2022的1…

【leetcode面试经典150题】64. 删除排序链表中的重复元素 II(C++)

【leetcode面试经典150题】专栏系列将为准备暑期实习生以及秋招的同学们提高在面试时的经典面试算法题的思路和想法。本专栏将以一题多解和精简算法思路为主&#xff0c;题解使用C语言。&#xff08;若有使用其他语言的同学也可了解题解思路&#xff0c;本质上语法内容一致&…

C++必修:从C语言到C++的过渡(上)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ &#x1f388;&#x1f388;养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; 所属专栏&#xff1a;C学习 贝蒂的主页&#xff1a;Betty’s blog 1. 什么是C C&#xff08;c plus plus&#xff09;是一种计算机高级程序设计语言&…

链表经典算法OJ题目

1.单链表相关经典算OJ题目1&#xff1a;移除链表元素 思路一 直接在原链表里删除val元素&#xff0c;然后让val前一个结点和后一个节点连接起来。 这时我们就需要3个指针来遍历链表&#xff1a; pcur —— 判断节点的val值是否于给定删除的val值相等 prev ——保存pcur的前…

【详细讲解下Photoshop】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

OpenHarmony 网络管理-Socket连接

介绍 本示例主要演示了Socket在网络通信方面的应用&#xff0c;展示了Socket在两端设备的连接验证、聊天通信方面的应用。 效果预览 使用说明 1.搭建服务器环境&#xff1a;修改服务器脚本中的服务端IP地址&#xff0c;与本机IP地址保持一致&#xff0c;修改完成后双击运行脚…

手撸词法分析器(C/C++)

手撸词法分析器&#xff08;C/C&#xff09; 一.背景二.什么是词法分析器&#xff1f;三.代码四.思考 一.背景 这学期开设了编译原理&#xff0c;要求写个基本的词法分析器。所以博主就自己写了一份代码&#xff0c;也比较简单基础。 二.什么是词法分析器&#xff1f; 简单来…

Unity实现动态数字变化

最近的项目需要动态显示数字&#xff0c;所以使用Text组件&#xff0c;将数字进行变化操作过程记录下来。 一、UI准备 1、新建一个Text组件 2、新建C#脚本 3、将Text挂载到脚本上 二、函数说明 1、NumberChange 方法 NumberChange 方法接收四个参数&#xff1a;初始数字 in…

设备连接IoT云平台指南

一、简介 设备与IoT云间的通讯协议包含了MQTT&#xff0c;LwM2M/CoAP&#xff0c;HTTP/HTTP2&#xff0c;Modbus&#xff0c;OPC-UA&#xff0c;OPC-DA。而我们设备端与云端通讯主要用的协议是MQTT。那么设备端与IoT云间是如何创建通信的呢&#xff1f;以连接华为云IoT平台为例…

不容忽视的办公网络安全威胁 零信任或成破局关键

移动互联网、混合云和 SaaS 时代的来临&#xff0c;让企业的办公网络环境发生着巨大变化&#xff0c; BYOD、移动办公以及访问云端 SaaS 应用的场景已经越来越频繁&#xff0c;在方便协作、提升效率的同时&#xff0c;潜在的安全威胁以及管理困境也日益突出。比如&#xff1a; …

快速入门Spring Data JPA

Spring Data JPA是Spring Data框架的一小部分&#xff0c;它能够让开发者能够更加简单的对数据库进行增删改查。 由于Spring Data JPA可以自动生成SQL代码所以一般情况下&#xff0c;简单的增删查改就可以交给Spring Data JPA来完成&#xff0c;而复杂的动态SQL等用MyBatis来完…

免费使用ChatGPT 4.0 和 文心一言 4.0

前言 今天给大家分享如何免费使用ChatGPT4.0 和 文心一言 4.0&#xff0c;废话就不多说了&#xff0c;我们直接入正题。 ChatGPT 4.0 先来看看如何免费使用ChatGPT 4.0 进入Coze登录 https://www.coze.com 选择大圣-GPT-4 文心一言 4.0 通过文心智能体平台&#xff0c;就…

[阅读笔记20][BTX]Branch-Train-MiX: Mixing Expert LLMs into a Mixture-of-Experts LLM

这篇论文是meta在24年3月发表的&#xff0c;它提出的BTX结构融合了BTM和MoE的优点&#xff0c;既能保证各专家模型训练时的高度并行&#xff0c;又是一个统一的单个模型&#xff0c;可以进一步微调。 这篇论文研究了以高效方法训练LLM使其获得各领域专家的能力&#xff0c;例如…

C++智能指针(二十)

一.RAII&#xff08;Resource Acquisition Is Initialization&#xff09; RAII资源获取即初始化&#xff0c;RAII的思想就是在构造时初始化资源&#xff0c;或者托管已经构造的资源。在析构的时候释放资源。一般不允许复制或赋值&#xff0c;并且提供若干的资源访问的方法。比…

openGauss学习笔记-265 openGauss性能调优-TPCC性能调优测试指导-操作系统配置

文章目录 openGauss学习笔记-265 openGauss性能调优-TPCC性能调优测试指导-操作系统配置265.1安装openEuler操作系统265.2 修改操作系统内核PAGESIZE为64KB。265.3 关闭CPU中断的服务irqbalance openGauss学习笔记-265 openGauss性能调优-TPCC性能调优测试指导-操作系统配置 本…

oracle一次sql优化笔记

背景&#xff1a;两个百万级数据量表需要连接&#xff0c;加全索引的情况下速度仍不见改善&#xff0c;苦查一下午解决问题未遂。 解决&#xff1a;经大佬指点了解到oracle优化器提示&#xff0c;使用/* USE_HASH(table1 table2) */或者/* USE_MERGE(table1 table2) */来指导优…

正则表达式中 “$” 并不是表示 “字符串结束”

△△请给“Python猫”加星标 &#xff0c;以免错过文章推送 作者&#xff1a;Seth Larson 译者&#xff1a;豌豆花下猫Python猫 英文&#xff1a;Regex character “$” doesnt mean “end-of-string” 转载请保留作者及译者信息&#xff01; 这篇文章写一写我最近在用 Python …

数图可视化品类空间管理系统入编《零售门店数字化赋能专项报告(2024年)》

数图可视化品类空间管理系统荣幸入编中国连锁经营协会发布的 《零售门店数字化赋能专项报告&#xff08;2024年&#xff09;》&#xff0c;报告以零售门店为切入点&#xff0c;通过引入“5P”的技术框架及梳理业内配套最佳实践方案&#xff0c;理出一套科学的、完整的零售门店数…