MySQL中的增查操作:探索数据的奥秘,开启数据之门

news2025/1/18 6:22:14

本节,我们继续深入了解MySQL,本章所讲的基础操作,针对的是表的增删查改! 

一、Create 新增

1.1、语法

INSERT [INTO] table_name
 [(column [, column] ...)]
VALUES
 (value_list) [, (value_list)] ...
value_list: value, [, value] ...

1.2、示例

student 表中新增喜羊羊及其id;

#单行数据全列插入
insert into student values (1,'喜羊羊');

#单行数据指定列插入
insert into student (name) values ('懒洋洋');
insert into student (id,name) values (3,'小灰灰');
 
#多行数据指定列插入
insert into student (id,name) values (4,'沸羊羊'),(5,'慢羊羊');

(1) 单行数据全列插入(如喜羊羊的插入)

(2) 单行数据指定列插入(如懒洋洋的插入,未设置默认值是,默认为NULL

(3) 多行数据指定列插入(如沸羊羊慢羊羊的插入)

由上述示例可知:插入一条新数据行时,字段名处可以是一个或者是多个,后面括号内应按照字段名的顺序,设置对应的值,若有字符串类型的值,应使用英文单引号包裹

 如果,我们插入的值与前面字段名顺序或数据类型不匹配时,会发生什么?

 insert into student (id,name) values ('测试','无名氏');

 insert into student (id,name) values ('测试','7');

报错:整数值不正确:第 1 行的列 'id' 的 'test'

二、Retrieve 查询

2.1、语法

SELECT
 [DISTINCT]
 select_expr [, select_expr] ...
 [FROM table_references]
 [WHERE where_condition]
 [GROUP BY {col_name | expr}, ...]
 [HAVING where_condition]
 [ORDER BY {col_name | expr } [ASC | DESC], ... ]
 [LIMIT {[offset,] row_count | row_count OFFSET offset}]

 2.2、示例

先创建如下空表:

 插入数据后,查询 student 表中的所有列:

 2.3、扩展

2.3.1、指定列查询

2.3.2、查询字段为表达式 
 2.3.3、列+常量

当我们给这些同学记录好成绩后,发现语文某题出错了,我们需要补偿给每位同学10分,这时我们可以用到该方法:

2.3.4、列+列

 既然列可以在需要的情况下加一个常量,那么列可以加列吗?答案是可以的!我们来演示一下,求一下每为同学的总成绩:

2.3.5、为查询结果指定别名 

上图所示可能有些麻烦,我们可以使用 as 简化一下,即可代替列名 如下:

select id,name,Chinese,Math,English,Chinese+Math+English as '总分' from student;

 注意:

        (1)as 是可省略的

        (2)别名可以不加单引号,但是别名中若存在空格,必须加引号

        (3)生成存在别名列的表为临时表,执行完输出之后就被删除

        (4)每个字段名后都可以加 as 代替当前字段名

 2.4、去重查询

 不久,我们班级新来了一个同学叫做“光头强”,顺利通过了考试,我们发现其英语成绩竟然和“懒羊羊”成绩一样!

英语老师要求列出所有英语分数,但是不准有重复的,我们就可以使用 distinct 关键字去重 :

2.5、Where 条件查询 

2.5.1、运算符
2.5.2、示例
2.5.2.1、基本查询

(1)查询英语为35分的同学

注意:此时当某位同学的英语成绩为NULL,查询结果会忽略该同学

select id,name,English
from student
where English=35;

(2) 查询英语成绩大于语文成绩的同学

select id,name,Chinese,English 
from student 
where English>Chinese;

 2.5.2.2、AND和OR

(1)查询语文成绩大于70分或英语成绩大于70分的同学

select id,name,Chinese,English 
from student 
where Chinese>70 or English>70;

 2.5.2.3、范围查询

(1)查询数学成绩范围在70和90之间的同学

select id,name,Math 
from student 
where Math between 70 and 90;

2.5.2.4、模糊查询 
select id,name 
from student 
where name like '%羊羊';

 多组其他测试如下:

2.5.2.5、NULL的查询 

同学们学习了几天后,又来了一位新同学“熊二”,由于它在英语考试中途太饿了,想要吃蜂蜜,所以英语成绩暂时没有:

但是老师不记得是谁没考英语成绩,就想调查一下:

select id,name,English
from student 
where English is null;

 2.6、Order by 排序

2.6.1、语法
SELECT ... FROM table_name [WHERE ...] ORDER BY {col_name | expr } [ASC |
DESC], ... ;

                 升序:ASC               降序:DESC

2.6.2、总成绩排名
select id,name,Chinese+Math+English as total 
from student 
order by total desc;

 (1)某列为NULL参与运算,与其他数值比较时,NULL被视为比任何值都小(包含负数)

 (2)ORDER BY 子句中可以使用列的别名进行排序

 (3)查询中没有ORDER BY 子句,返回的顺序是未定义的

2.7、分页查询 

老师要查找总成绩前三的同学及其总成绩:

select id,name,Chinese+Math+English as total 
from student 
order by total desc 
limit 0,3;

 三、总结

本篇我们详细讲解了增添,查询的各个操作,如有缺漏,欢迎在评论区补充,看完本篇,我们来补充一个小知识,观察下面代码:

 为什么使用 where 条件查询时,不能使用别名?

奥奇小课堂:

        这和MYSQL中执行SQL语句的顺序有关:

(1)要查询数据,先要确定表,先执行 from

(2)查询过程中要根据查询条件把符合条件的数据过滤出,此时执行 where

(3)执行 select 后面的指定列,这些列需要加入最终结果

(4)排序操作,根据 order by 指定的列名和排序规则执行最后的排序

本篇到此结束,内容详细,制作不易,求赞啦啦啦~~ 

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

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

相关文章

WIFI(1)

WIFI(1) 目录 WIFI(1) 回顾 WIFI模块 -- 1、AP模式:(服务器)应用:主要是用来让用户设置自身的wifi密码 -- 2、STA模式:可以获取时间获取天气 应用: 代…

暴力破解案例

暴力破解 1 概述 暴力破解,是一种针对密码的破译方法,将密码进行逐个推算直到找出真正的密码为止。 2 爆破HTTP协议 第一步:实验性发送请求成功 import requests url "http://192.172.0.100:8080/woniusales/user/login"data {"use…

CUDA - nvprof 性能刨析

nvprof 是一个可执行文件&#xff0c;使用everything搜索可以看到它在&#xff1a; 执行命令&#xff1a; nvprof exe_name 如何在windows 下使用&#xff0c;可以参看: windows下使用nvcc和nvprof。 示例 #include <cuda_runtime.h> #include <device_launch_par…

YOLOv8实战水果识别【数据集+YOLOv8模型+源码+PyQt5界面】

本文采用YOLOv8作为核心算法框架&#xff0c;结合PyQt5构建用户界面&#xff0c;使用Python3进行开发。YOLOv8以其高效的实时检测能力&#xff0c;在多个目标检测任务中展现出卓越性能。本研究针对水果数据集进行训练和优化&#xff0c;该数据集包含丰富的水果图像样本&#xf…

Merlion笔记(二):单变量时间预测

1 简单示例 我们首先导入Merlion的TimeSeries类和M4数据集的数据加载器。然后&#xff0c;我们可以将该数据集中的特定时间序列划分为训练集和测试集。 from merlion.utils import TimeSeries from ts_datasets.forecast import M4time_series, metadata M4(subset"Hou…

ClickHouse入库时间与实际相差8小时问题

原因一&#xff1a;服务端未修改默认时区 解决方案&#xff1a; 1、找 ClickHouse 配置文件 config.xml&#xff0c;通常位于 /etc/clickhouse-server/ 目录。 2、编辑 config.xml 文件&#xff0c;找到 标签。如果标签不存在&#xff0c;需要手动添加。 3、修改 标签的内容为 …

docker部署dvwa靶场

一、简述前情 最近差不多又是网安专业的同学搭建靶场的时候了&#xff0c;DVWA&#xff08;Damn Vulnerable Web Application&#xff09;是安全入门者们最为熟知的练习靶场&#xff0c;它能够帮助小白对常见的安全问题进行理解&#xff0c;并且随着理解问题的深入自主调整靶场…

Redis-02 数据持久化

redis持久化即将数据从内存写入磁盘&#xff0c;Redis提供了两种持久化的方式&#xff1a;RDB和AOF。 1.RDB RDB持久化&#xff1a;Redis可以将内存中的数据定期快照保存到磁盘上的一个二进制文件中。RDB持久化是一种比较紧凑的文件格式&#xff0c;适用于备份和灾难恢复。通过…

vue3中监视 Reactive对象中的属性

watch 的第一个参数可以是不同形式的“数据源”&#xff1a;它可以是一个 ref (包括计算属性)、一个响应式对象、一个 getter 函数、或多个数据源组成的数组 一、框架&#xff1a; <template><div class"divBox"><h2>姓名&#xff1a;{{ person.…

【深圳大学/大学物理实验2】超声探伤实验 实验前预习题答案参考

一、单选题 共 6 小题 共 31 分 1. (5分)电偶极矩的单位是&#xff08; &#xff09; 学生答案&#xff1a;B √ A. B. C. D. 2. (5分)本实验中产生超声波的方法是&#xff08; &#xff09; 学生答案&#xff1a;D √ A. 热电效应 B. 光电效应 C. 电磁效应 D. 压电效…

【专题】关系数据库标准语言SQL

1. SQL语言介绍 SQL(Structured Query Language)是结构化查询语言&#xff0c;它是一种在关系数据库中定义和操纵数据的标准语言&#xff0c;是用户与数据库之间进行交流的接口。 1.1 SQL数据库的体系结构 使用SQL关系数据库的特点&#xff1a; SQL用户可以是应用程序&#xf…

闯关leetcode——100. Same Tree

大纲 题目地址内容 解题代码地址 题目 地址 https://leetcode.com/problems/same-tree/description/ 内容 Given the roots of two binary trees p and q, write a function to check if they are the same or not. Two binary trees are considered the same if they are…

PHP简单登录系统

目录 用户数据文件 (users.php) HTML 登录表单 (login.html) PHP 登录处理脚本 (login_process.php) 欢迎页面 (welcome.php) 注销脚本 (logout.php) 效果展示 用户名和密码错误时 用户名和密码正确时 用户数据文件 (users.php) 用于保存用户信息&#xff0c;用户名和他…

【PUSCH的时域资源分配】

DCI format 0_0/0_1用于调度PDSCH传输&#xff0c;每种格式都包含了时域和频域资源的分配字段。 和PDSCH一样&#xff0c;PUSCH也支持Type A和Type B两种映射类型&#xff0c;但是有效的S和L组合不同。 同样&#xff0c;当UE通过DCI调度PUSCH时&#xff0c;DCI的时域资源分配…

日语学习柯桥外语培训jlpt备考「意地」是什么意思?

「意地」 N1单词 意地&#xff08;いじ&#xff09; 词性&#xff1a;名词 含义&#xff1a;心术&#xff0c;用心&#xff1b;固执&#xff0c;倔强&#xff1b;志气&#xff0c;气魄&#xff1b;嘴馋&#xff0c;贪婪 例句&#xff1a; ▲自分が始めたことだから意地でもや…

长三角智驾花絮

杜轩第一次去说服清洁工&#xff0c;收养狗儿&#xff0c;结果清洁工说有人收养了狗&#xff0c;结果狗引起交通事故主人赔钱。第二次尝试说服大妈收养狗儿&#xff0c;大妈给狗儿一脚&#xff0c;说狗儿把她厕所搞脏了。第三次看路上的美女&#xff0c;去说服美女收养&#xf…

UE5运行时动态加载场景角色动画任意搭配-全流程代码(四)

UE5运行时动态加载场景、角色、角色动画、相机动画任意搭配,Android、iOS也可以跑,横竖屏兼容,手机竖屏: 1、场景切换UWorld处理 在通过OpenLevel进行场景切换的时候,UWorld会发生变化,需要我们获取正确的UWorld。 1、在GameInstance监听Level加载 void UMyGameInsta…

nemo-guardrails简单应用

环境&#xff1a;openEuler、python 3.11.6、nemoguardrails 0.10.1、Azure openAi 背景&#xff1a;工作需要&#xff0c;进行调研期间&#xff0c;发现问题太多&#xff0c;且国内网站好多没说明具体问题 时间&#xff1a;20241014 说明&#xff1a;搭建过程中主要是下载h…

ARMA3 STATUS_ACCESS _VIOLATION退出解决方法测试

方法1 [SOLVED] 0xc0000005 status_access_violation ARMA 3 (youtube.com) 启动器-参数-平台 改32位。 没卵用。 方法2 ArmA 3 "STATUS_ACCESS_VIOLATION" FIX!! [2018] (youtube.com) steam-ARMA3-属性-通用-启动选项&#xff1a;粘贴路径&#xff0c;后面加-…

基于FPGA的以太网设计(三)

通过前文介绍了RGMII接口时序我们可以知道&#xff0c;RGMII接口是在时钟信号的上升沿和下降沿均进行数据的传输&#xff0c;而FPGA则在时钟的单沿传输数据&#xff0c;因此我们需要编写代码将RGMII接口转换为GMII接口。 由于前面的介绍我们知道RTL8211默认工作在延时状态&…