数据库系统概论(超详解!!!) 第四节 关系数据库标准语言SQL(Ⅱ)

news2025/1/9 6:11:55

1.数据查询

SELECT [ ALL | DISTINCT] <目标列表达式>
                         [,<目标列表达式>] …
FROM <表名或视图名>[, <表名或视图名> ] …
[ WHERE <条件表达式> ]
[ GROUP BY <列名1> [ HAVING <条件表达式> ] ]
[ ORDER BY <列名2> [ ASC|DESC ] ];

SELECT子句:指定要显示的属性列

FROM子句:指定查询对象(基本表或视图)

WHERE子句:指定查询条件

GROUP BY子句:对查询结果按指定列的值分组,该属性列值相等的元组为一个组。通常会在每组中作用聚集函数。

HAVING短语:只有满足指定条件的组才予以输出

ORDER BY子句:对查询结果表按指定列值的升序或降序排序

1.单表查询

查询仅涉及一个表

1.选择表中的若干列

查询指定列:

查询全体学生的学号与姓名。

SELECT Sno, Sname
FROM Student; 

选出所有属性列: 在SELECT关键字后面列出所有列名或 将<目标列表达式>指定为 *

SELECT  Sno,Sname,Ssex,Sage,Sdept 
FROM Student; 
   或
SELECT  *
FROM Student; 

查询需要计算的值

SELECT子句的<目标列表达式>可以为: 算术表达式; 字符串常量; 函数 ;列别名。

查全体学生的姓名及其出生年份

SELECT Sname,2004-Sage    /*假定当年的年份为2004年*/
FROM Student;

查询全体学生的姓名、出生年份和所有系,要求用小写字母表示所有系名

SELECT Sname, 'Year of Birth:' , 2004-Sage, LOWER(Sdept)   
FROM Student;

使用列别名改变查询结果的列标题:

SELECT 原名 新名,……

SELECT Sname NAME, 'Year of Birth: ’  BIRTH,
               2000-Sage  BIRTHDAY, LOWER(Sdept)  DEPARTMENT
	FROM Student;

2.选择表中的若干元组

1.消除取值重复的行       

如果没有指定DISTINCT关键词,则缺省为ALL

SELECT Sno   
FROM SC;
	等价于:
SELECT ALL  Sno  
FROM SC;

指定DISTINCT关键词,去掉表中重复的行    
SELECT DISTINCT Sno   
FROM SC; 
2.查询满足条件的元组

常用查询条件:

1.比较大小

查询计算机科学系全体学生的名单
SELECT Sname  
FROM Student
WHERE Sdept=‘CS’ ; 

查询所有年龄在20岁以下的学生姓名及其年龄
SELECT Sname,Sage  
FROM    Student    
WHERE Sage < 20;

查询考试成绩有不及格的学生的学号。
SELECT DISTINCT  Sno    
FROM  SC
WHERE Grade<60;

2.确定范围

BETWEEN …  AND  …                  

NOT BETWEEN  …  AND  …

查询年龄在20~23岁(包括20岁和23岁)之间的学生的姓名、系别和年龄
    SELECT Sname,Sdept,Sage   FROM Student
    WHERE Sage  BETWEEN 20 AND 23;

查询年龄不在20~23岁之间的学生姓名、系别和年龄
	       SELECT Sname,Sdept,Sage  FROM    Student
	       WHERE Sage NOT BETWEEN 20 AND 23; 

3.确定集合

IN <值表>

NOT IN <值表>

查询信息系(IS)、数学系(MA)和计算机科学系(CS)学生的姓名和性别。
           SELECT Sname,Ssex  FROM  Student
           WHERE Sdept IN ( 'IS','MA','CS' );

查询既不是信息系、数学系,也不是计算机科学系的学生的姓名和性别。
SELECT Sname,Ssex  FROM Student
	 WHERE Sdept NOT IN ( 'IS‘,'MA‘,'CS' );

4.字符匹配

[NOT] LIKE  ‘<匹配串>’  [ESCAPE ‘ <换码字符>’]

1)匹配串为固定字符串

查询学号为201215121的学生的详细情况。
     SELECT  *    FROM  Student  
     WHERE  Sno  LIKE  ‘201215121';
等价于: 
      SELECT  * 
      FROM  Student 
      WHERE Sno = ‘ 201215121 ’;
若LIKE后的匹配串不含通配符,则与=等价

2)匹配串为含通配符的字符串

查询所有姓刘学生的姓名、学号和性别。
      SELECT Sname,Sno,Ssex
      FROM Student
      WHERE  Sname LIKE ‘刘%’;

查询姓"欧阳"且全名为三个汉字的学生的姓名。
      SELECT Sname
      FROM   Student
      WHERE  Sname LIKE '欧阳_‘;

查询名字中第2个字为"阳"字的学生的姓名和学号。
      SELECT Sname,Sno
      FROM Student
      WHERE Sname LIKE ‘_阳%’;

查询所有不姓刘的学生姓名。
      SELECT Sname,Sno,Ssex
      FROM Student
      WHERE Sname NOT LIKE ‘刘%’;

查询名字里包含“阳”的学生的姓名和学号。
      SELECT Sname,Sno
      FROM Student
      WHERE Sname LIKE ‘%阳%’;

查询姓刘或者姓李的学生姓名和学号。
      SELECT Sname,Sno
      FROM Student
      WHERE Sname LIKE ‘[刘李] %’

3)使用换码字符将通配符转义为普通字符

查询DB_Design课程的课程号和学分。
      SELECT Cno,Ccredit
      FROM Course
      WHERE Cname LIKE ‘DB\_Design’ ESCAPE ‘\’;

查询以"DB_"开头,且倒数第2个字符为 i的课程的详细情况。
      SELECT  *
      FROM   Course
      WHERE  Cname LIKE  'DB\_%i_' ESCAPE ' \ ‘;

 ESCAPE '\' 表示“ \” 为换码字符

5.涉及空值的查询(NULL)

IS NULL 或 IS NOT NULL

 “IS” 不能用 “=” 代替

某些学生选修课程后没有参加考试,所以有选课记录,但没有考试成绩。查询缺少成绩的学生的学号和相应的课程号。
	 SELECT Sno,Cno
      FROM  SC
      WHERE  Grade IS NULL
查所有有成绩的学生学号和课程号。
      SELECT Sno,Cno
      FROM  SC
      WHERE  Grade IS NOT NULL

6.多重条件查询

逻辑运算符:AND和 OR来联结多个查询条件  

AND的优先级高于OR  ,可以用括号改变优先级

可用来实现多种其他谓词  

[NOT] IN

 [NOT] BETWEEN …   AND  …

查询计算机系年龄在20岁以下的学生姓名。
     SELECT Sname
     FROM  Student
     WHERE Sdept= 'CS' AND Sage<20;

查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名和性别。
SELECT Sname, Ssex
FROM     Student
WHERE  Sdept IN ('CS ','MA ','IS')

可改写为:

SELECT Sname, Ssex
FROM     Student
WHERE  Sdept= ' CS' OR Sdept= ' MA' OR Sdept= 'IS ';

3.ORDER BY子句

可以按一个或多个属性列排序

升序:ASC;降序:DESC;缺省值为升序

当排序列含空值时

ASC:排序列为空值的元组最先显示

DESC:排序列为空值的元组最后显示

查询选修了3号课程的学生的学号及其成绩,查询结果按分数降序排列。
     SELECT Sno,Grade  FROM  SC
        WHERE  Cno= ‘3’
        ORDER BY Grade DESC;

查询全体学生情况,查询结果按所在系的系号升序排列,同一系中的学生按年龄降序排列。
SELECT  *  
FROM  Student  
ORDER BY Sdept,Sage DESC; 

4.聚集函数

统计元组个数      

COUNT(*) 统计一列中值的个数      

COUNT([DISTINCT|ALL] <列名>)

计算一列值的总和(此列必须为数值型)

SUM([DISTINCT|ALL] <列名>)    

计算一列值的平均值(此列必须为数值型)

AVG([DISTINCT|ALL] <列名>)

求一列中的最大值和最小值      

MAX([DISTINCT|ALL] <列名>)     

MIN([DISTINCT|ALL] <列名>)

查询学生总人数。
SELECT COUNT(*)
FROM  Student; 

查询选修了课程的学生人数。
SELECT COUNT(DISTINCT Sno)
FROM SC;

计算3号课程的学生平均成绩。
SELECT AVG(Grade)
FROM SC
WHERE Cno= ' 3 ';

查询选修3号课程的学生最高分数。
SELECT MAX(Grade)
FROM SC
WHER Cno= ‘3 ‘;

查询学生201215122选修课程的总学分数。
SELECT SUM(Ccredit)
FROM  SC, Course
WHERE Sno='201215122' AND
      SC.Cno=Course.Cno; 

5.GROUP BY子句

GROUP BY子句分组:      

细化聚集函数的作用对象  如果未对查询结果分组,聚集函数将作用于整个查询结果  

对查询结果分组后,聚集函数将分别作用于每个组

按指定的一列或多列值分组,值相等的为一组

求各个课程号及相应的选课人数。
     SELECT Cno,COUNT(Sno)
     FROM    SC
     GROUP BY Cno; 

查询选修了3门以上课程的学生学号。
     SELECT Sno
     FROM  SC
     GROUP BY Sno
     HAVING  COUNT(*) >3;

查询平均成绩大于等于90分的学生学号和平均成绩
    SELECT  Sno, AVG(Grade)
    FROM  SC
    GROUP BY Sno
    HAVING AVG(Grade)>=90;
WHERE子句中不能用聚集函数作为条件表达式

HAVING短语与WHERE子句的区别: 作用对象不同

WHERE子句作用于基表或视图,从中选择满足条件的元组

HAVING短语作用于组,从中选择满足条件的组。

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

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

相关文章

数据分析POWER BI之power query

1.导入数据 ctrla全选--数据--获取数据--其他来源--来自表格/区域 导入数据&#xff0c;进入编辑模式 2.整理与清除 清除&#xff1a;删除所选列的非打印字符 转换--格式--清除 修整&#xff1a;删除前面和后面的空格 转换---格式---修整&#xff08;修整后前面后面的空格没有了…

【研发管理】产品经理知识体系-战略

导读&#xff1a;了解和掌握产品经理知识体系-战略是产品经理必修课。战略在产品创新管理框架中核心位置。本文概要梳理战略相关知识内容&#xff0c;仅供大家参考。 目录 1、战略定义 1.1 战略金字塔 1.2 战略的层级总表 1.3 战略跟战术的关系 1.4 愿景、使命和价值观​编…

Pillow教程05:NumPy数组和PIL图像的相互转化

---------------Pillow教程集合--------------- Python项目18&#xff1a;使用Pillow模块&#xff0c;随机生成4位数的图片验证码 Python教程93&#xff1a;初识Pillow模块&#xff08;创建Image对象查看属性图片的保存与缩放&#xff09; Pillow教程02&#xff1a;图片的裁…

uni-app框架(项目创建)

1.学习说明 dcloud官方除uni-app外&#xff0c;还有新生的uni-app x&#xff08;即下一代uni-app&#xff09;&#xff0c;如果是初学者或者刚入门同学&#xff0c;建议还是使用uni-app进行开发。 无论是vue还是uni&#xff0c;作为前端开发的一个框架学习方法是一致的&#…

扩展自动化,超越RPA的局限

白皮书大纲 01 概述 02 端到端流程超越节省的时间 03 企业自动化与机器人流程自动化的对比 04 将RPA集成到企业工作流程中 05 实现端到端自动化——构建流程 06 中枢神经系统&#xff1a;一个编排平台 07 结合RPA和数环通iPaaS的益处 01 概述 企业运营依赖于流程。有效的流程是…

城市排涝与海绵城市规划设计中的水文水动力模拟技术应用

随着计算机的广泛应用和各类模型软件的发展&#xff0c;将排水系统模型作为城市洪灾评价与防治的技术手段已经成为防洪防灾的重要技术途径。本次培训将聚焦于综合利用GIS及CAD等工具高效地进行大规模城市排水系统水力模型的建立&#xff0c;利用SWMM实现排水系统水力模拟。讲解…

FastAPI+React全栈开发02 什么是FARM技术栈

Chapter01 Web Development and the FARM Stack 02 What is the FARM stack and how does it fit together? FastAPIReact全栈开发02 什么是FARM技术栈 It is important to understand that stacks aren’t really special, they are just sets of technologies that cover…

政安晨:【Keras机器学习实践要点】(三)—— 编写组件与训练数据

政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras实战演绎机器学习 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff01; 介绍 通过 Keras&#xff0c;您可以编写自定…

【数据结构】顺序表的定义

&#x1f388;个人主页&#xff1a;豌豆射手^ &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;数据结构 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进…

【牛客】SQL142 对试卷得分做min-max归一化

描述 现有试卷信息表examination_info&#xff08;exam_id试卷ID, tag试卷类别, difficulty试卷难度, duration考试时长, release_time发布时间&#xff09;&#xff1a; idexam_idtagdifficultydurationrelease_time19001SQLhard602020-01-01 10:00:0029002Chard802020-01-0…

SQLite使用的临时文件(二)

返回&#xff1a;SQLite—系列文章目录 上一篇&#xff1a;SQLite数据库文件损坏的可能几种情况 下一篇&#xff1a;SQLite数据库成为内存中数据库&#xff08;三&#xff09; ​ 1. 引言 SQLite的显着特点之一它是一个数据库由一个磁盘文件组成。 这简化了 SQLite 的使用…

【动态规划】Leetcode 62. 不同路径

【动态规划】Leetcode 62. 不同路径 解法 ---------------&#x1f388;&#x1f388;62. 不同路径 题目链接&#x1f388;&#x1f388;------------------- 解法 &#x1f612;: 我的代码实现> 动规五部曲 ✒️确定dp数组以及下标的含义 dp[i][j] 走到i, j这个格子的…

Open WebUI大模型对话平台-适配Ollama

什么是Open WebUI Open WebUI是一种可扩展、功能丰富、用户友好的大模型对话平台&#xff0c;旨在完全离线运行。它支持各种LLM运行程序&#xff0c;包括与Ollama和Openai兼容的API。 功能 直观的界面:我们的聊天界面灵感来自ChatGPT&#xff0c;确保了用户友好的体验。响应…

(四)图像的%2线性拉伸

环境&#xff1a;Windows10专业版 IDEA2021.2.3 jdk11.0.1 OpenCV-460.jar 系列文章&#xff1a; &#xff08;一&#xff09;PythonGDAL实现BSQ&#xff0c;BIP&#xff0c;BIL格式的相互转换 &#xff08;二&#xff09;BSQ,BIL,BIP存储格式的相互转换算法 &#xff08;三…

Netty剖析 - 掌握Netty 整体架构脉络

文章目录 Netty 整体结构Core 核心层Protocol Support 协议支持层Transport Service 传输服务层 Netty 逻辑架构网络通信层事件调度层服务编排层组件关系梳理 Netty 源码结构Core 核心层模块Protocol Support 协议支持层模块Transport Service 传输服务层模块 思维导图 Netty 整…

机器学习OpenNLP

版权声明 本文原创作者&#xff1a;谷哥的小弟作者博客地址&#xff1a;http://blog.csdn.net/lfdfhl OpenNLP概述 OpenNLP是一个基于机器学习的自然语言处理开发工具包&#xff0c;它是Apache软件基金会的一个开源项目。OpenNLP支持多种自然语言处理任务&#xff0c;如分词、…

云数据库认识

云数据库概述 说明云数据库厂商概述Amazon 云数据库产品Google 的云数据库产品Microsoft 的云数据库产品 云数据库系统架构UMP 系统概述UMP 系统架构MnesiaRabbitMQZooKeeperLVSController 服务器Proxy 服务器Agent 服务器日志分析服务器 UMP 系统功能容灾 读写分离分库分表资源…

如何利用python 把一个表格某列数据和另外一个表格某列匹配 类似Excel VLOOKUP功能

环境: python3.8.10 Excel2016 Win10专业版 问题描述: 如何利用python 把一个表格某列数据和另外一个表格某列匹配 类似Excel VLOOKUP功能 先排除两表A列空白单元格,然后匹配x1表格和x2表格他们的A列,把x1表格中A列A1-A810范围对应的B列B1-B810数据,匹配填充到x2范围…

android studio忽略文件

右键文件&#xff0c;然后忽略&#xff0c;就不会出现在commit里面了 然后提交忽略文件即可

纯前端调用本机原生Office实现Web在线编辑Word/Excel/PPT,支持私有化部署

在日常协同办公过程中&#xff0c;一份文件可能需要多次重复修改才能确定&#xff0c;如果你发送给多个人修改后再汇总&#xff0c;这样既效率低又容易出错&#xff0c;这就用到网页版协同办公软件了&#xff0c;不仅方便文件流转还保证不会出错。 但是目前一些在线协同Office…