SQL-查询结果显示-投影、去重、重命名、排序

2024-06-11 15:20

本文主要是介绍SQL-查询结果显示-投影、去重、重命名、排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、数据查询

1、数据查询是指根据用户需求从数据库中提取数据并将查询结果显示出来,SQL语言中的SELECT语句可以完成数据查询

2、完整的数据查询语句的格式:

SELECT 【ALL|DISTINCT】<目标列表达式1>【,<目标列表达式2>,...】

FROM <表名或视图名1>【,<表名或视图名2>,...】

WHERE <元组选择条件表达式>】

GROUP BY <属性列名1>【,<属性列2>,...】【HAVING <组选择条件表达式>】】

ORDER BY <目标列名1>【ASC|DESC】【,<目标列名2>【ASC|DESC】,...】】

3、SELECT语句中包含了FROM子句、WHERE子句、GROUP子句、ORDER子句四部分

4、SELECT语句具有数据查询、计算、分组统计、排序四个功能

二、对单个数据表查询结果的处理

1、投影属性列

(1)SELECT语句格式:

SELECT 【ALL|DISTINCT】<目标列表达式1>【,<目标列表达式2>,...】

FROM <表名>(要求此时的目标列表达式为属性列名)

(2)例1:查询并显示所有学生的部分信息

select sNo,sN,sex,sB,sD from s;

结论:语句中的属性列的列的顺序与查询结果中的属性列的顺序是一致的

(3)例2:查询并显示所有学生的全部信息(可以使用*来代替所有属性列的列名)

select * from s;

结论:结果表中属性列的顺序与定义表时属性列的顺序一致

2、去除重复元组

(1)DBMS中默认在SELECT语句中使用的ALL选项,默认在结果表中会显示重复的元组

例:查询选修了课程的学生的学号

select sNo from sC;

 

(2)在SELECT语句中手动设置DISTINCT选项可实现在结果表中不显示重复的元组

select distinct sNo from sC;

3、计算查询结果

(1)目标列表达式可以除了可以是属性列外,也可以是与属性列相关的表达式,包括函数、字符串常量、运算符三种形式

(2)通常函数中常用到的是聚集函数(集合作为入参,单个值作为返回值)

常用的六个聚集函数

注意:

第一个:COUNT(*)是算值全为NULL的元组;其它四个是不算值为NULL的列值的;

第二个:SUM 和 AVG要求列的数据类型必须为数值型;

举例:查询了选修了课程的学生人数

select count(distinct sNo) from sC;

(3)非聚焦函数

datediff(datepart,startdate,enddate):

三个参数:要返回的时间间隔的类型,起始日期或时间,结束日期或时间

作用:计算两个日期之间的差值

Getdate():获取系统当前的日期

举例:查询所有学生的的学号年龄

select sNo,DATEDIFF(YEAR,sB,GETDATE())+1 from s;

4、对目标列命名

(1)DBMS默认不会给给查询结果表中的新列命名

(2)手动给新列命名的两种方式

AS,可省略但必须空格隔开

=,不可省略

(3)举例:查询所有学生的的学号年龄

select sNo AS 学号,年龄=DATEDIFF(YEAR,sB,GETDATE())+1 from s;
select sNo 学号,年龄=DATEDIFF(YEAR,sB,GETDATE())+1 from s;

5、对查询结果排序

(1)默认情况下,DBMS按照元组在数据表中的位置来输出查询结果,想要使得查询结果按照目标列(一个或者多个)的值的升序或者降序来进行输出,就要使用到ORDER BY子句ASC(升序、默认)DESC(降序)

(2)ORDER BY子句格式:

SELECT 【ALL|DISTINCT】<目标列表达式1>【,<目标列表达式2>,...】

FROM <表名>

ORDER BY <目标列1> 【ASC|DESC】【,<目标列>【ASC|DESC】,...】

(3)注意:

先按第一列排序,第一列相同再按第二列排序,以此类推

(4)举例1:查询所有选修信息,按课程号升序排列

select * from sC 
order by Cno;

(5)举例2:查询所有选修信息,按课程号升序排列,同一课程内的按学生成绩升序排列

select * from sC 
order by Cno,grade asc;

(6)ORDER BY后面的目标列除了用列名来表示,还可以用目标列在SELECT子句中出现的顺序号表示(按没有列名的列的值对查询结果进行排序输出时只能使用该方法)

举例:查询查询所有学生的的学号和年龄并按年龄升序输出

select sNo 学号,年龄=DATEDIFF(YEAR,SB,GETDATE())from s
order by 年龄 asc;

三、总结

1、SELECT子句可以通过对属性列进行投影来输出查询结果,通过去重和给属性列起名来美化查询结果

2、ORDER BY子句可以让查询结果按照指定目标列的排序或降序方式排列

这篇关于SQL-查询结果显示-投影、去重、重命名、排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1051543

相关文章

Python实现文件批量重命名器

《Python实现文件批量重命名器》在日常工作和学习中,我们经常需要对大量文件进行重命名操作,本文将介绍一个使用Python开发的文件批量重命名工具,提供了多种重命名模式,有需要的小伙伴可以了解下... 目录前言功能特点模块化设计1.目录路径获取模块2.文件列表获取模块3.重命名模式选择模块4.序列号参数配

Java JSQLParser解析SQL的使用指南

《JavaJSQLParser解析SQL的使用指南》JSQLParser是一个Java语言的SQL语句解析工具,可以将SQL语句解析成为Java类的层次结构,还支持改写SQL,下面我们就来看看它的具... 目录一、引言二、jsQLParser常见类2.1 Class Diagram2.2 Statement

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

MySQL数据库实现批量表分区完整示例

《MySQL数据库实现批量表分区完整示例》通俗地讲表分区是将一大表,根据条件分割成若干个小表,:本文主要介绍MySQL数据库实现批量表分区的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录一、表分区条件二、常规表和分区表的区别三、表分区的创建四、将既有表转换分区表脚本五、批量转换表为分区

宝塔安装的MySQL无法连接的情况及解决方案

《宝塔安装的MySQL无法连接的情况及解决方案》宝塔面板是一款流行的服务器管理工具,其中集成的MySQL数据库有时会出现连接问题,本文详细介绍两种最常见的MySQL连接错误:“1130-Hostisn... 目录一、错误 1130:Host ‘xxx.xxx.xxx.xxx’ is not allowed

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

sql语句字段截取方法

《sql语句字段截取方法》在MySQL中,使用SUBSTRING函数可以实现字段截取,下面给大家分享sql语句字段截取方法,感兴趣的朋友一起看看吧... 目录sql语句字段截取sql 截取表中指定字段sql语句字段截取1、在mysql中,使用SUBSTRING函数可以实现字段截取。例如,要截取一个字符串字

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

SQL Server身份验证模式步骤和示例代码

《SQLServer身份验证模式步骤和示例代码》SQLServer是一个广泛使用的关系数据库管理系统,通常使用两种身份验证模式:Windows身份验证和SQLServer身份验证,本文将详细介绍身份... 目录身份验证方式的概念更改身份验证方式的步骤方法一:使用SQL Server Management S

MySQL 字符串截取函数及用法详解

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST... 目录mysql 字符串截取函数详解RIGHT(str, length):从右侧截取指定长度的字符SUBST