MYSQL之增删改查(中)

 前言:

         以下是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 ,genderFROM student2;

结果:

注意:

      字段顺序可以更改,如:

SELECT id,grade,gender ,nameFROM 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.mzph.cn/news/826554.shtml

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

相关文章

Gamba:将高斯溅射与Mamba结合用于单视图3D重建

Gamba: Marry Gaussian Splatting with Mamba for Single-View 3D Reconstruction Gamba&#xff1a;将高斯溅射与Mamba结合用于单视图3D重建 Qiuhong Shen11  Xuanyu Yi31 Zike Wu31  Pan Zhou2,42 Hanwang Zhang3,5 沈秋红 1 易轩宇 3 吴子可 3 潘周 2,4 2 张汉旺 3,5Shu…

C语言开源库iniparser解析ini文件

1 ini文件介绍 INI&#xff08;Initialization File&#xff09;文件是一种简单直观的数据存储格式&#xff0c;常用于配置应用程序的初始化设置。这种文件通常包含若干个节&#xff08;section&#xff09;和键值对&#xff08;key-value pairs&#xff09;。INI文件的每一部…

Spring AOP(面向切面编程)

1.Spring AOP 简介 1.1 AOP概述 AOP 为 Aspect Oriented Programming 的缩写&#xff0c;意思为面向切面编程, 是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP 是 OOP 的延续&#xff0c;是Spring框架中的一个重要内容&#xff0c;是函数式编程的一…

FPGA Quartus IP核 打开使用

两种Quartus版本下的IP核&#xff0c;从使用者的角度来看仅仅是配置界面不同&#xff0c;在参数设置和使用方法上基本一致。本文以“MegaWizard Plug-In Manager”中的FIR Compiler IP核使用为例。 Quartus的FIR IP核属于收费IP&#xff0c;如果是个人学习使用需要对IP核单独破…

C++ 深入理解 继承

本篇文章将谈谈一下几个问题&#xff1a; 1.基类和派生类对象赋值转换 2.继承中的作用域 3.派生类的默认成员函数 4.复杂的菱形继承及菱形虚拟继承 5.其他 1.基类和派生类对象赋值转换 1.派生类对象 可以赋值给 基类的对象 / 基类的指针 / 基类的引用。这里有个形象的说法叫切…

【电控笔记2.5】位置闭环回路设计

总结 List item 位置控制器 加入前馈 总结

SpringBoot基于JavaWeb的菜鸟驿站快递管理系统ssm

前端&#xff1a;vue.jsElementUI 编程语言: java 框架&#xff1a; ssm/springboot 详细技术&#xff1a;springboot springbootvueMYSQLMAVEN 数据库: mysql5.7 数据库工具&#xff1a;Navicat/SQLyog都可以 ide工具&#xff1a;IDEA 或者eclipse 对菜鸟驿站快递管理系统设计…

会议文字记录工具【钉钉闪记】

当开会时&#xff0c;需要文字记录会议内容&#xff0c;但是打字又慢&#xff0c;可以使用钉钉闪记。 钉钉工作台直接搜索-钉钉闪记

ADSP-21479的开发详解九(CCES开发详解)

硬件准备 ADSP-21479EVB开发板&#xff1a; 产品链接&#xff1a;https://item.taobao.com/item.htm?id555500952801&spma1z10.5-c.w4002-5192690539.11.151441a3Z16RLU AD-HP530ICE仿真器&#xff1a; 产品链接&#xff1a;https://item.taobao.com/item.htm?id38007…

【PythonCode】力扣Leetcode16~20题Python版

【PythonCode】力扣Leetcode16~20题Python版 前言 力扣Leetcode是一个集学习、刷题、竞赛等功能于一体的编程学习平台&#xff0c;很多计算机相关专业的学生、编程自学者、IT从业者在上面学习和刷题。 在Leetcode上刷题&#xff0c;可以选择各种主流的编程语言&#xff0c;如C…

React【Day4下+5】

环境搭建 使用CRA创建项目&#xff0c;并安装必要依赖&#xff0c;包括下列基础包 Redux状态管理 - reduxjs/toolkit 、 react-redux路由 - react-router-dom时间处理 - dayjsclass类名处理 - classnames移动端组件库 - antd-mobile请求插件 - axios 配置别名路径 1. 背景知识…

【Linux 进程间通信】管道

文章目录 1.System V 标准介绍2.进程间通信的方式&#xff1f;3.管道&#xff08;匿名管道&#xff09; 1.System V 标准介绍 ①&#x1f34e; System V 实际上就是一个标准&#xff08;“ 行业领头羊制定出来的专利 " &#xff09; 2.进程间通信的方式&#xff1f; …

linux下摄像头设置固定的设备名

目录 2.热插拔udev机制 3.设置udev的规则 1.查看usb ID 2. 查看usb设备的信息 3.编译规则 4.拓展 1.问题的出现 通过我之前的文章配置完摄像头的开机自启动之后我们会发现有的时候会出现启动不了的情况&#xff0c;通过实验我发现是摄像头的设备名发生了改变&#xff0c;…

ADSP-21479的开发详解五(AD1939 C Block-Based Talkthru 48 or 96 kHz)音频直通

硬件准备 ADSP-21479EVB开发板&#xff1a; 产品链接&#xff1a;https://item.taobao.com/item.htm?id555500952801&spma1z10.5-c.w4002-5192690539.11.151441a3Z16RLU AD-HP530ICE仿真器&#xff1a; 产品链接&#xff1a;https://item.taobao.com/item.htm?id38007…

开源数据集分享——猫脸码客

开源数据集分享&#xff0c;让数据更自由流通——猫脸码客带你走进数据的新世界 在数字化时代的浪潮中&#xff0c;数据已经成为推动社会进步的重要力量。然而&#xff0c;数据的获取与利用往往受到种种限制&#xff0c;使得许多有价值的信息难以被充分挖掘。幸运的是&#xf…

适配器模式【结构型模式C++】

1.概述 适配器模式是一种结构型设计模式&#xff0c; 又称为变压器模式、包装模式&#xff08;Wrapper&#xff09; 将一个类的接口变换成客户端所期待的另一种接口&#xff0c;从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作。 2.结构 Target&#xff1a;适配…

Leetcode算法训练日记 | day31

专题九 贪心算法 一、分发饼干 1.题目 Leetcode&#xff1a;第 455 题 假设你是一位很棒的家长&#xff0c;想要给你的孩子们一些小饼干。但是&#xff0c;每个孩子最多只能给一块饼干。 对每个孩子 i&#xff0c;都有一个胃口值 g[i]&#xff0c;这是能让孩子们满足胃口的…

【算法一则】矩阵置零 【矩阵】【空间复用】

题目 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,1,1],[1,0,1],[1,1,1]] 输出&#xff1a;[[1,0,1],[0,0,0],[1,0,1]]示例 2&#xff1a; …

冰达ROS机器人快速使用指南

欢迎来到《冰达ROS机器人极简使用指南》 Q&#xff1a;这份教程适合谁&#xff1f; A&#xff1a;适合完全0基础新手&#xff0c;需要快速跑起来机器人的基本功能。也适合技术大佬需要快速的了解冰达ROS机器人的使用方法。 Q&#xff1a;这份教程内容很少&#xff0c;是不是…

机器学习基本流程

Jupyter Notebook 代码连接&#xff1a; machine_learning_demo machine_learning_ensembles Step 1: Imports and Configuration import pandas as pd import numpy as np import copy import json import pickle import joblib import lightgbm as lgb import optuna impor…