关系数据库标准语言SQL(7,8)

news2024/10/2 11:14:15

目录

选择表中若干元组

消除取值重复的行

查询满足条件的元组

比较大小

确定范围

确定集合

字符匹配

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

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

涉及空值的查询

多重条件查询

order by字句

例子

聚集函数

GROUP BY 子句

HAVING语句与WHERE语句的区别


选择表中若干元组

消除取值重复的行

如果没有指定DISTINCT关键词,

则缺省为ALL

【例】查询选修了课程的学生学号。 SELECT Sno FROM SC;等价于:SELECT ALL Sno FROM SC;

没distinct默认为all。

【例】指定DISTINCT关键词,去掉表中重复的行。 SELECT DISTINCT Sno FROM SC;

查询满足条件的元组

查询满足条件的元组可以通过where子句实珂,where常用的查询条件如下:

确定范围 BETWEEN AND,NOT BETWEEN AND

确定集合 IN,NOT IN

字符匹配 LIKE,NOT LIKE

空值 IS NULL,IS NOT NULL

多重条件(逻辑运算) AND,OR,NOT

还有比较>,<,>=等,其中<>是不等于的意思与!=同义

比较大小

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

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

distinct保证查出的学号不重复。

确定范围

【例】查询年龄在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;

确定集合

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

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

字符匹配

【例】查询学号为200215121的学生的详细情况。 SELECT FROM Student WHERE Sno LIKE 200215121';等价于: SELECT FROM Student WHERE Sno='200215121';

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

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

【例】查询姓“欧阳”且全名为三个汉字的学生的姓名 SELECT Sname FROM Student WHERE Sname LIKE‘欧阳_’;

【例】查询名字中第二个字为“阳”字的学生的姓名和学号。 SELECT Sname,Sno FROM Student WHERE Sname LIKE‘_阳%’

【例】查询所有不姓刘的学生姓名、学号和性别。 SELECT Sname,Sno,Ssex FROM Student WHERE S Sname NOT LIKE 刘%;

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

SELECT FROM Course WHERE Cname LIKE'DB\_%i ESCAPE \

说明:ESCAPE表示为换码字符。这里的\表示like里出现的一个_是实际的_而不是空出来的一个字符。

涉及空值的查询

谓词:IS NULL或IS NOT NULL“1S”不能用=代替。

多重条件查询

用逻辑运算符AND和OR来联结多个查询条件,AND的优先级高于 OR,可以用括号改变优先级。可用来实现多种其他谓词:[NOT] IN[NOT]BETWEEN AND

order by字句

ORDER BY子句可以按一个或多个属性列排序:

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

当排序列含空值时:空值默认为最大值 

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

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

例子

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

聚集函数

COUNT([DISTINCT|ALL]统计元组个数

COUNT[DISTINCT |ALL<列名>)统计一列中值的个数

SUM([DISTINCT|ALL]列名>)计算一列值的总和(此列必须是数值型

AVG ([DISTINCT |ALL]<列名>)计算一列值的平均值(此列必须是数值型)

MAX[DISTINCT ALL]<列名>)求一列值的最大值

MIN[DISTINCT ALL]<列名>)求一列值的最小值

【注意】,WHERE子句中是不能用聚集函数作为条件表达式的。聚集函数只能用于SELECT子句和GROUPBY中的HAVING子句。

GROUP BY 子句

GROUP BY子句作用是:按指定的一列或多列值分组,值相等为一组,来细化聚集函数的作用对象

【说明】①未对查询结果分组,聚集函数将作用于整个查询结

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

GROUPE BY子句分组后,可以使用HAVING:短语指定筛选条件。

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

HAVING语句与WHERE语句的区别

①作用对象不同:WHERE-子句作用千基表或视图,从中选择满足条件的元组。

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

②WHERE子句中是不能用聚集函数作为条件表达式的

【例】查询平均成绩大于等于90分的学生学号和平均成绩。

下面的语句是不对的: SELECT Sno,AVG (Grade) FROM SC WHERE AVG (Grade)>=90 GROUP BY Sno

正确的查询语句应该是: SELECT Sno,AVG (Grade) FROM SC GROUP BY Sno HAVING AVG (Grade)>=90;

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

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

相关文章

Ubuntu22.04之测试两个IP地址的网速(二百七十一)

简介&#xff1a; CSDN博客专家、《Android系统多媒体进阶实战》一书作者 新书发布&#xff1a;《Android系统多媒体进阶实战》&#x1f680; 优质专栏&#xff1a; Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a; 多媒体系统工程师系列【…

微信小程序操作蓝牙

主要流程&#xff1a; 1.初始化蓝牙适配器openBluetoothAdapter&#xff0c;如果不成功就onBluetoothAdapterStateChange监听蓝牙适配器状态变化事件 2.startBluetoothDevicesDiscovery开始搜寻附近的蓝牙外围设备 3.onBluetoothDeviceFound监听寻找到新设备的事件&#xff0c;…

制造业该如何应用大数据?

​收到一位朋友私信&#xff0c;提问“制造业该如何应用大数据”&#xff1f;我觉得这个问题非常好&#xff0c;而且这也将是未来机械专业领域的一个重要突破口。 而传统制造企业与计算机、互联网行业的最佳结合点就在这里。 如果你没有真正的去实施过一个企业的信息化项目&a…

【重学 MySQL】四十五、数据库的创建、修改与删除

【重学 MySQL】四十五、数据库的创建、修改与删除 一条数据存储的过程数据输入数据验证数据处理数据存储数据持久化反馈与日志注意事项 标识符命名规则基本规则长度限制保留字与特殊字符命名建议示例 MySQL 中的数据类型创建数据库创建数据库时指定字符集和排序规则 查看数据库…

[Linux]开发环境搭建

RPM和YUM 安装JDK 安装Tomcat 安装IDEA 安装MySql

代码随想录算法训练营Day20 | 235. 二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作、450.删除二叉搜索树中的节点

目录 235. 二叉搜索树的最近公共祖先 701.二叉搜索树中的插入操作 450.删除二叉搜索树中的节点 235. 二叉搜索树的最近公共祖先 题目 235. 二叉搜索树的最近公共祖先 - 力扣&#xff08;LeetCode&#xff09; 给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先…

Yocto - 使用Yocto开发嵌入式Linux系统_05 认识Bitbake工具

Meeting the BitBake Tool 通过本章&#xff0c;我们将开始学习 Yocto 项目引擎如何在幕后工作的旅程。正如每一段旅程一样&#xff0c;沟通是至关重要的&#xff0c;因此我们需要理解 Yocto 项目工具所使用的语言&#xff0c;并学习如何充分利用这些工具来实现我们的目标。 Wi…

网页前端开发之Javascript入门篇(3/9):条件控制

Javascript条件控制 什么是条件控制&#xff1f; 答&#xff1a;其概念跟 Python教程 介绍的一样&#xff0c;只是语法上有所变化。 参考流程图如下&#xff1a; 其对应语法&#xff1a; var button false; // 开关状态 console.log("检查开关.."); if(bu…

一文掌握Harbor镜像同步公有云镜像仓库实践

一文掌握Harbor镜像同步公有云镜像仓库实践 目录 1 引言2 概念 2.1 Harbor2.2 阿里云的镜像仓库ACR2.3 华为云的镜像仓库SWR2.4 Harbor复制管理同步镜像 2.4.1 复制管理的工作原理 2.5 Harbor同步镜像到公有云镜像仓库的优势 3 实验&#xff1a;通过Harbor 将容器镜像同步到公…

刷题系统小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;知识点管理&#xff0c;科目类型管理&#xff0c;试题管理&#xff0c;试卷管理&#xff0c;系统管理 微信端账号功能包括&#xff1a;系统首页&#xff0c;我的 开发系统&#…

vulnhub-W34kn3ss 1靶机

vulnhub&#xff1a;https://www.vulnhub.com/entry/w34kn3ss-1,270/ 导入靶机&#xff0c;扫描 靶机开在192.168.81.7.扫描端口 扫到三个端口&#xff0c;存在网站服务&#xff0c;访问 80端口没什么东西&#xff0c;443似乎访问到的是同一个界面&#xff0c;这种情况下一般是…

Visual Studio C# 处理和修复 WinRiver II 测量项目 MMT 文件错误

Visual Studio C# 处理和修复 WinRiver II 测量项目 MMT 文件错误 前言一、WinRiver II 测量项目 MMT 文件的结构二、WinRiver II 无法打开或操作测量项目 MMT 文件2.1 无法载入船测多线法测量文件2.2 可以载入测验项目 MMT 文件&#xff0c;但 ADCP 后处理软件无法写入信息2.3…

基于SpringBoot+vue的监理公司信息化管理系统设计与实现

目录 1. 系统概述 2. 技术选型 3. 系统模块设计 3.1 收入支出管理 3.2 合同管理 3.3 财务统计 3.4 甲方乙方公告 4. 安全性考虑 5. 效果展示和示例代码 6. 总结 1. 系统概述 随着经济的快速发展和社会的进步&#xff0c;建筑行业作为国民经济的重要支柱产业之…

[MAUI]数据绑定和MVVM:MVVM的属性验证

一、MVVM的属性验证案例 Toolkit.Mvvm框架中的ObservableValidator类,提供了属性验证功能,可以使用我们熟悉的验证特性对属性的值进行验证,并将错误属性提取和反馈给UI层。以下案例实现对UI层的姓名和年龄两个输入框,进行表单提交验证。实现效果如下所示 View<ContentP…

医院体检管理系统小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;体检分类管理&#xff0c;体检套餐管理&#xff0c;体检预约管理&#xff0c;体检报告管理&#xff0c;系统管理 微信端账号功能包括&#xff1a;系统首页&#xff0c;体检套餐&a…

Jetson 开发系列:Orin Nano 开箱!一款强大的嵌入式物联网开发板

边缘计算作为 AI 的一个重要应用场景&#xff0c;面临着前所未有的机遇与挑战。 谈及 AI&#xff0c;自然绕不开 NVIDIA 的产品&#xff1a; 其中&#xff0c;Jetson 系列均为 AIoT 设备打造&#xff0c;功耗低是其最大的特点。以我手头的 Jetson Ori Nano 为例&#xff0c;满…

一文彻底搞懂多模态 - 基础术语+基础知识+多模态学习

文章目录 技术交流基本术语一、数据采集与表示二、数据处理与融合三、学习与推理 基础知识一、传统机器学习二、深度学习三、优化算法四、应用领域 多模态学习一、模态表示二、多模态融合图片 三、跨模态对齐 最近这一两周看到不少互联网公司都已经开始秋招发放Offer。 不同以…

【MAUI】View和ViewModel的关联方式

方式一:创建ViewModel对象: 在View中,通过设置BindingContext为ViewModel对象,即可进行绑定。如下所示: <ContentPage......xmlns:vm="clr-namespace:MauiApp8.ViewModels"><

多模态RAG实现

在标准 RAG 中&#xff0c;输入文档包含文本数据。LLM 利用上下文学习&#xff0c;通过检索与所提查询上下文相匹配的文本文档块来提供更相关、更准确的答案。 但是&#xff0c;如果文档包含图像、表格、图表等以及文本数据&#xff0c;该怎么办&#xff1f; 不同的文档格式包…

基于 Qwen2.5-0.5B 微调训练 Ner 命名实体识别任务

一、Qwen2.5 & 数据集 Qwen2.5 是 Qwen 大型语言模型的最新系列&#xff0c;参数范围从 0.5B 到 72B 不等。 对比 Qwen2 最新的 Qwen2.5 进行了以下改进&#xff1a; 知识明显增加&#xff0c;并且大大提高了编码和数学能力。在指令跟随、生成长文本&#xff08;超过 8K…