MySQL 从零开始:06 数据检索

news2025/4/6 18:30:05

文章目录

  • 1、数据准备
  • 2、限制结果
  • 3、完全限定名
  • 4、排序检索

所谓数据检索,就是前面所讲的”增删改查“的”“。

注:本文使用的“行”指数据表中的“记录”,“列”指数据表中的“字段”。

在第四节《表的增删改查》中已经介绍了 select 查询记录的几种使用方法:查询所有行的所有列、查询指定行的所有列、查询所有行的指定列和查询指定行的指定列。本文介绍一些数据检索的其他高级使用方法。

1、数据准备

首先准备文需要的数据,如下图所示:

01_成绩表

使用如下语句进行数据库的创建、表的创建及记录的插入:

mysql> create database scoredb;
Query OK, 1 row affected (0.08 sec)

mysql> use scoredb;
Database changed

mysql> CREATE TABLE score(
    -> name VARCHAR(4) NOT NULL DEFAULT '',
    -> math_score TINYINT NOT NULL DEFAULT 0,
    -> chinese_score TINYINT NOT NULL DEFAULT 0,
    -> english_score TINYINT NOT NULL DEFAULT 0
    -> )engine myisam charset utf8;
Query OK, 0 rows affected, 1 warning (0.08 sec)

mysql> INSERT INTO score VALUES 
    -> ('赵一', 87, 90, 79),
    -> ('钱二', 80, 87, 92),
    -> ('孙三', 89, 94, 90),
    -> ('李四', 74, 85, 97),
    -> ('王五', 79, 71, 91),
    -> ('周六', 73, 84, 77),
    -> ('吴七', 94, 90, 93),
    -> ('郑八', 87, 98, 97),
    -> ('冯九', 69, 82, 83),
    -> ('陈十', 96, 97, 96);
Query OK, 10 rows affected (0.00 sec)
Records: 10  Duplicates: 0  Warnings: 0

2、限制结果

SELECT 语句返回所有的匹配行,它们可能是指定表中的每个行。如果想要SELECT 语句返回指定的行数,可以使用LIMIT 子句。 LIMIT 接受一个或两个数字的参数,参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。

LIMIT 三种语法,第二种和第三种语法完全等价:

SELECT column1, column2, columnN 
FROM table_name
LIMIT [no of rows];
SELECT column1, column2, columnN 
FROM table_name
LIMIT [row num] [no of rows];
SELECT column1, column2, columnN 
FROM table_name
LIMIT [no of rows] OFFSET [row num];

注:

  • 初始记录行的偏移量为 0 。

示例1,检索前3条记录:

mysql> SELECT name FROM score LIMIT 3;
+------+
| name |
+------+
| 赵一 |
| 钱二 |
| 孙三 |
+------+
3 rows in set (0.00 sec)

示例2,检索从偏移量为5的记录开始后3条记录:

mysql> SELECT name FROM score LIMIT 5, 3;
+------+
| name |
+------+
| 周六 |
| 吴七 |
| 郑八 |
+------+
3 rows in set (0.00 sec)

也可以使用下面这种语法:

mysql> SELECT name FROM score LIMIT 3 OFFSET 5;
+------+
| name |
+------+
| 周六 |
| 吴七 |
| 郑八 |
+------+
3 rows in set (0.00 sec)

在行数不够时,LIMIT 中指定要检索的行数为检索的最大行数。比如我们从第8条记录开始取5条记录,那么我们只能取到3条记录:

mysql> SELECT name FROM score LIMIT 5 OFFSET 7;
+------+
| name |
+------+
| 郑八 |
| 冯九 |
| 陈十 |
+------+
3 rows in set (0.01 sec)

3、完全限定名

假如两个表中有相同的字段,而我们恰好要查询其中一个表中的该字段,那么就会出现二义性:到底要取哪个表中的该字段?为了解决这一问题,可以使用完全限定的名字来引用列,完全限定字段的格式为table_name.column_name,例如:

mysql> SELECT score.name FROM score;
+------+
| name |
+------+
| 赵一 |
| 钱二 |
| 孙三 |
| 李四 |
| 王五 |
| 周六 |
| 吴七 |
| 郑八 |
| 冯九 |
| 陈十 |
+------+
10 rows in set (0.01 sec)

表名也是可以被限制的,其格式为database_name.table_name,例如:

mysql> SELECT score.name FROM scoredb.score;
+------+
| name |
+------+
| 赵一 |
| 钱二 |
| 孙三 |
| 李四 |
| 王五 |
| 周六 |
| 吴七 |
| 郑八 |
| 冯九 |
| 陈十 |
+------+
10 rows in set (0.00 sec)

4、排序检索

有时候数据并不是一定要按照数据库中的存储顺序进行显示,比如我们想要以商品价格进行排序或者以成绩排名进行显示。

如果我们需要对读取的数据进行排序,可以使用 MySQL 的 ORDER BY 子句来设定想按哪个字段哪种方式来进行排序,再返回搜索结果。其语法为:

SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
  • 可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
  • 可以设定多个字段来排序。
  • 可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。 默认情况下,它是按升序排列。
  • 可以添加 WHERE…LIKE 子句来设置条件。

以数学成绩升序方式检索,可以使用如下命令:

mysql> SELECT name, math_score FROM score ORDER BY math_score;
+------+------------+
| name | math_score |
+------+------------+
| 冯九 |         69 |
| 周六 |         73 |
| 李四 |         74 |
| 王五 |         79 |
| 钱二 |         80 |
| 赵一 |         87 |
| 郑八 |         87 |
| 孙三 |         89 |
| 吴七 |         94 |
| 陈十 |         96 |
+------+------------+
10 rows in set (0.00 sec)

以数学成绩降序方式检索,可以使用如下命令:

mysql> SELECT name, math_score FROM score ORDER BY math_score DESC;
+------+------------+
| name | math_score |
+------+------------+
| 陈十 |         96 |
| 吴七 |         94 |
| 孙三 |         89 |
| 赵一 |         87 |
| 郑八 |         87 |
| 钱二 |         80 |
| 王五 |         79 |
| 李四 |         74 |
| 周六 |         73 |
| 冯九 |         69 |
+------+------------+
10 rows in set (0.00 sec)

以数学成绩升序、语文成绩降序和英语成绩降序 3 个字段同时检索:

mysql> SELECT name, math_score, chinese_score, english_score FROM score ORDER BY
    -> math_score, chinese_score DESC, english_score DESC;
+------+------------+---------------+---------------+
| name | math_score | chinese_score | english_score |
+------+------------+---------------+---------------+
| 冯九 |         69 |            82 |            83 |
| 周六 |         73 |            84 |            77 |
| 李四 |         74 |            85 |            97 |
| 王五 |         79 |            71 |            91 |
| 钱二 |         80 |            87 |            92 |
| 郑八 |         87 |            98 |            97 |
| 赵一 |         87 |            90 |            79 |
| 孙三 |         89 |            94 |            90 |
| 吴七 |         94 |            90 |            93 |
| 陈十 |         96 |            97 |            96 |
+------+------------+---------------+---------------+
10 rows in set (0.00 sec)

利用排序检索与 LIMIT 组合,可以取出某字段的最低或最高记录。

mysql> SELECT name, english_score FROM score ORDER BY english_score LIMIT 1;
+------+---------------+
| name | english_score |
+------+---------------+
| 周六 |            77 |
+------+---------------+
1 row in set (0.00 sec)

mysql> SELECT name, english_score FROM score ORDER BY english_score DESC LIMIT 1;
+------+---------------+
| name | english_score |
+------+---------------+
| 李四 |            97 |
+------+---------------+
1 row in set (0.00 sec)

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

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

相关文章

C# Cad2016二次开发api(三)

直线 Line 属性中文数据类型作用Length长度double直线的长度Angle角度double直线的弧度,0~2πDelta增量Vector3d起点到终点的向量Normal法向向量Vector3d直线所在平面的法向单位向量Thickness厚度doubleEndPoint终点Point3d直线的终点StartPoint起点Point3d直线的起…

Memory Wall in Neural Network Inference

Memory Wall in Neural Network Inference 神经网络推理的瓶颈在于访存带宽,通常无法发挥出加速器的全部算力。本文总结了目前常用的推理加速器及其设计,并分析了常用神经网络的访存瓶颈。文章大部分内容参考自Computer Architecture: A Quantitative A…

JavaScript基础(26)_dom增删改练习

<!DOCTYPE html> <html lang"zh"><head><meta charset"UTF-8"><title>DOM增删改练习</title><link rel"stylesheet" href"../browser_default_style/reset.css"><style>table {borde…

软件测试|Selenium StaleElementException异常的原因与方法

简介 在使用Selenium进行Web自动化测试时&#xff0c;我们可能会遇到StaleElementException异常。这个异常通常在我们操作一个之前已经找到的元素时抛出&#xff0c;但该元素已经不再处于DOM树中&#xff0c;导致元素过时&#xff08;stale&#xff09;。本文将介绍StaleEleme…

C++11 左右值引用、移动语义

右值引用和移动语义 什么是左值&#xff1f;什么是左值引用&#xff1f; 左值是一个表示数据的表达式(如变量名或解引用的指针)&#xff0c;我们可以获取它的地址可以对它赋值&#xff0c;左值可以出现赋值符号的左边&#xff0c;右值不能出现在赋值符号左边。定义时const修饰…

SpringSecurity入门demo(二)表单认证

上一篇博客集成 Spring Security&#xff0c;使用其默认生效的 HTTP 基本认证保护 URL 资源&#xff0c;下面使用表单认证来保护 URL 资源。 一、默认表单认证&#xff1a; 代码改动&#xff1a;自定义WebSecurityConfig配置类 package com.security.demo.config; import or…

基于python的基金分析可视化系统

项目背景&#xff1a; 随着金融市场的发展和人们对财富管理的重视&#xff0c;越来越多的人开始参与基金投资。然而&#xff0c;由于市场上基金产品众多且复杂&#xff0c;投资者往往难以快速准确地获取基金信息和进行分析&#xff0c;从而导致投资决策不够科学和有效。为了解决…

PyCharm安装使用教程2024

简介 PyCharm是一种PythonIDE&#xff08;Integrated Development Environment&#xff0c;集成开发环境&#xff09;&#xff0c;带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具&#xff0c;比如调试、语法高亮、项目管理、代码跳转、智能提示、自动完成、单…

三棋先手必胜证明

目录 创作原因 游戏规则 初始状态图 证明过程 先手必胜的证明 失败的博弈树&#xff08;三个多小时的成果&#xff09; 创作原因 这个棋不是网上流行的成三棋&#xff0c;我也不知道这个棋叫什么。由于这个棋是&#xff08;横竖斜&#xff09;连成三个就获胜&#xff0c;…

Vulnhub-HACKSUDO: PROXIMACENTAURI渗透

文章目录 一、前言1、靶机ip配置2、渗透目标3、渗透概括 开始实战一、信息获取二、端口敲门三、web密码爆破四、getShell五、获取新用户六、提权 一、前言 由于在做靶机的时候&#xff0c;涉及到的渗透思路是非常的广泛&#xff0c;所以在写文章的时候都是挑重点来写&#xff0…

【同济子豪兄斯坦福CS224W中文精讲】NetworkX代码学习笔记

文章目录 安装配置创建图可视化图图数据挖掘参考资料 安装配置 matplotlib中文字体设置 import networkx as nx import matplotlib.pyplot as plt # 魔法指令&#xff0c;设置后在jupyter notebook中绘制的图形会显示在输出单元格中&#xff0c;而不是弹出一个新窗口 %matplo…

ssm基于Javaweb的网上奶茶店系统的设计与实现论文

摘 要 计算机网络发展到现在已经好几十年了&#xff0c;在理论上面已经有了很丰富的基础&#xff0c;并且在现实生活中也到处都在使用&#xff0c;可以说&#xff0c;经过几十年的发展&#xff0c;互联网技术已经把地域信息的隔阂给消除了&#xff0c;让整个世界都可以即时通话…

爬虫之牛刀小试(四):爬取B站番剧的简介

今天爬取的是b站。 如何爬取b站中的番剧呢&#xff1f; 首先我们来到番剧索引中&#xff0c;随便点开一部动漫&#xff0c;检查代码。 每个作品对应一个链接: https://www.bilibili.com/bangumi/play/ss…&#xff08;ss后面的数字称为ss号&#xff09; 发现关于动漫的信息…

【数据库】sql优化有哪些?从query层面和数据库层面分析

目录 归纳sql本身的优化数据库层面的优化 归纳 这类型问题可以称为&#xff1a;Query Optimization&#xff0c;从清华AI4DB的paper list中&#xff0c;该类问题大致可以分为&#xff1a; Query RewriterCardinality EstimationCost EstimationPlan Optimization 从中文的角…

某厂校招一道关于C的笔试题

一、笔试原题 题目&#xff1a;在Linux x86 _ 54 gcc环境下&#xff0c;下面的程序会出现什么问题&#xff1f;运行结果是什么&#xff1f;为什么&#xff1f; 程序如下图&#xff1a; 通过在gcc的环境下编译运行&#xff0c;发现运行结果为不断死循环打印0-17的数字 我们…

TCP之三次握手四次挥手与UDP区别

文章目录 1 TCP三次握手四次挥手1.1 数据包说明1.1.1 TCP数据包1.1.2 UDP数据包1.1.3 TCP和UDP差异1.1.4 TCP可靠性传输机制 1.2 三次握手1.2.1 三次握手定义1.2.2 三次握手问题1.2.2.1 问题引入分析1.2.2.2 历史连接1.2.2.3 同步双方初始序列号1.2.2.4 避免资源浪费 1.3 四次挥…

Github Copilot AI保密级教程

Copilot 是一款由 OpenAI 推出的人工智能代码自动补全AI工具&#xff0c;它可以帮助程序员更快、更准确地编写代码。Copilot 的核心技术基于 GPT-3 模型&#xff0c;但是在编码方面是优于GPT-3的&#xff0c;它可以根据程序员输入的上下文和代码提示&#xff0c;自动生成符合语…

微信小程序如何自定义导航栏,怎么确定导航栏及状态栏的高度?导航栏被刘海、信号图标给覆盖了怎么办?

声明&#xff1a;本文为了演示效果&#xff0c;颜色采用的比较显眼&#xff0c;可根据实际情况修改颜色 问题描述 当我们在JSON中将navigationStyle设置成custom后&#xff0c;当前页面的顶部导航栏就需要我们制作了&#xff0c;但出现了一下几个问题&#xff1a; 导航栏的高…

51-12 多模态论文串讲—BLIP 论文精读

视觉语言预训练VLP模型最近在各种多模态下游任务上获得了巨大的成功&#xff0c;目前还有两个主要局限性: (1) 模型角度: 大多数方法要么采用encoder模型&#xff0c;要么采用encoder-decoder模型。然而&#xff0c;基于编码器的模型不太容易直接转换到文本生成任务&#xff0…

高德打车引入“红绿灯倒计时”能力,算力技术升级打车体验

打到的车还有多久能到&#xff1f;接驾车辆原地不动是什么原因&#xff1f;乘客在打车时&#xff0c;常常因为无法了解实时接驾路况&#xff0c;容易出现“等车焦虑”。 如今&#xff0c;高德打车已全面应用“红绿灯倒计时”能力&#xff0c;让乘客在等车时就能掌握接驾路况&am…