MySQL 从零开始:06 数据检索

文章目录

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

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

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

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

1、数据准备

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

01_成绩表

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

mysql> create database scoredb;
Query OK, 1 row affected (0.08 sec)mysql> use scoredb;
Database changedmysql> 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.mzph.cn/news/619644.shtml

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

相关文章

Hive命令行运行SQL将数据保存到本地如何去除日志信息

1.场景分析 先有需求需要查询hive数仓数据并将结果保存到本地,但是在操作过程中总会有日志信息和表头信息一起保存到本地,不符合业务需要,那如何才能解决该问题呢? 废话不多少,直接上代码介绍: 2.问题解决…

回归预测 | Matlab实现SSA-CNN-LSTM-Attention麻雀优化卷积长短期记忆神经网络注意力机制多变量回归预测(SE注意力机制)

回归预测 | Matlab实现SSA-CNN-LSTM-Attention麻雀优化卷积长短期记忆神经网络注意力机制多变量回归预测(SE注意力机制) 目录 回归预测 | Matlab实现SSA-CNN-LSTM-Attention麻雀优化卷积长短期记忆神经网络注意力机制多变量回归预测(SE注意力…

计算机网络NCEPU复习资料

目录 一.概述: 计算机网络组成: 计算机网络分类: 计算机网络体系结构: C/S架构与P2P架构区别: OSI开放式系统互连参考模型: OSI开放式系统互连参考模型 相关协议: 五层协议网…

Vue.js设计与实现阅读-3

Vue设计与实现阅读-3 1、声明式描述UI2、渲染器3、组件4、模板的工作原理5、Vue.js 是各个模块组成的有机整体 前言 前面一章我们了解了,开发体验是衡量一个框架的重要指标之一。提供友好的警告信息至关重要,但是越详细的警告信息,意味着框架…

5 微信小程序

功能开发 5 功能开发概要今日详细1.发布1.1 发布流程的问题1.2 组件:进度条1.3 修改data中的局部数据1.4 发布示例效果前端后端 1.5 闭包 2.获取前10条新闻(动态/心情,无需分页)3.复杂版4.文章详细页面 各位小伙伴想要博客相关资料…

【python入门】day26: 模拟高铁售票系统

界面 代码 #-*- coding:utf-8 -*- import prettytable as pt#---------导入漂亮表格 import os.path filename ticket.txt#更新座位状态 def update(row_num):#------更新购票状态with open(filename,w,encodingutf-8) as wfile:for i in range(row_num):lst1 [f{i1},有票,有…

Modbus协议学习第一篇之基础概念

什么是“协议” 大白话解释:协议是用来正确传递消息数据而设立的一种规则。传递消息的双方(两台计算机)在通信时遵循同一种协议,即可理解彼此传递的消息数据。 Modbus协议模型 Modbus协议模型较为简单,使用一种称为应用…

soc算法【周末总结】

1 实验一(SOC误差30%放电实验) 1.1 实验过程 1、对电池包进行充电,将昨天放空的电池包进行充电,充电至SOC40%左右; 2、电池包SOC为38%时,手动修改SOC值为70%,开始放电 3、SOC由70%缓慢降至4…

Windows下面基于pgsql15的备份和恢复

一、基础备份 1.创建一个文件用来存储备份数据 2.备份指令 $CurrentDate Get-Date -Format "yyyy-MM-dd" $OutputDirectory "D:\PgsqData\pg_base\$CurrentDate" $Command "./pg_basebackup -h 127.0.0.1 -U postgres -Ft -Pv -Xf -z -Z5 -D $O…

教育观察期刊投稿邮箱、投稿要求

《教育观察》创刊于2012年,是国家新闻出版总署批准的正规教育类学术期刊,本刊致力于在教育实践中以“观察”为方法,以“观察者”为主体,以“新观察”为旨趣,打造从教育实践中洞察教育未来的教育研究与交流的平台。主要…

关于Quartz远程调用服务方法失败如何解决,@Inner详细介绍

1.单独在要调用服务的controller写上相关方法(Inner(value true)要走aop,会检测是否有内部调用标识)具体见下述 2. 编写Feign远程调用的接口,注意加上RequestHeader(SecurityConstants.FROM) String from。因为inner(value true…

【LabVIEW FPGA入门】LabVIEW FPGA实现I2S解码器

该示例演示了如何使用 LabVIEW FPGA 解码 IS 信号。该代码可用于大多数支持高速数字输入的LabVIEW FPGA 目标(例如R 系列、CompactRIO)。IS 用于对系统和组件内的数字音频数据进行编码。例如,MP3 播放器或 DVD 播放器内部的数字音频通常使用 …

【从零开始学习Java重要集合】深入解读ThreadLocal类

目录 前言: ThreadLocal: ThreadLocal的内部结构: ThreadLocal的常用方法: 1.set方法: 2.get方法: 3.setInitialValue方法 remove方法(): ThreadLocalMap&…

MySQL数据库入门到大牛_高级_00_MySQL高级特性篇的内容简介

文章目录 一、整个MySQL的思维导图二、MySQL高级特性篇大纲1. MySQL架构篇2. 索引及调优篇3. 事务篇4. 日志与备份篇 一、整个MySQL的思维导图 下图为整个MySQL内容,01-05是基础篇,06-09是高级篇 二、MySQL高级特性篇大纲 MySQL高级特性分为4个篇章&…

mybatisplus配置

一、新建项目&#xff1a;com.saas.plusdemo 二、配置pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:sch…

双向冒泡排序的数据结构实验报告

目录 实验目的&#xff1a; 实验内容&#xff08;实验题目与说明&#xff09; 算法设计&#xff08;核心代码或全部代码&#xff09; 运行与测试&#xff08;测试数据和实验结果分析&#xff09; 总结与心得&#xff1a; 实验目的&#xff1a; 理解双向冒泡排序算法的原…

2023年全国职业院校技能大赛软件测试赛题—单元测试卷⑧

单元测试 一、任务要求 题目1&#xff1a;根据下列流程图编写程序实现相应处理&#xff0c;执行j10*x-y返回文字“j1&#xff1a;”和计算值&#xff0c;执行j(x-y)*(10⁵%7)返回文字“j2&#xff1a;”和计算值&#xff0c;执行jy*log(x10)返回文字“j3&#xff1a;”和计算值…

山西电力市场日前价格预测【2024-01-13】

日前价格预测 预测说明&#xff1a; 如上图所示&#xff0c;预测明日&#xff08;2024-01-13&#xff09;山西电力市场全天平均日前电价为231.81元/MWh。其中&#xff0c;最高日前电价为345.71元/MWh&#xff0c;预计出现在00:15。最低日前电价为0.00元/MWh&#xff0c;预计出…

node-sass@4.7.2 postinstall: `node scripts/build.js`

Can‘t find Python executable “D:\Python36\python.EXE“, you can set the PYTHON env variable.-CSDN博客 gyp ERR! build error gyp ERR! stack Error: C:\Windows\Microsoft.NET\Framework\v4.0.30319\msbuild.exe failed with exit code: 1 gyp ERR! stack at Chil…

uniapp怎么开发插件并发布

今天耳机坏了,暂时内卷不了,所以想开发几个插件玩玩,也好久没写博客了,就拿这个来写了 首先,发布插件时需要你有项目 这里先拿uniapp创建一个项目, 如下,创建好的项目长这样 然后根据uniapp官网上说的,我们发布插件时,需要在uni_modules里面编写和发布 ps:还需要使用uniapp…