数据库sql语句练习(较难)

简介: 数据库sql语句练习(较难)

例题:关系较复杂

f4825e8e85dc4b9aa37bed63fdda840b.png747182779add4c7c98344d4c896cf783.png


 personinstory表                                 love表

7716e3aa6bac4894a323ecbf90ea0557.pngdff3e3a6535c448188b76827c2cc8dde.png


先按照性别,然后按照美丽程度由高往低的顺序, 列出所有人物的名字,性别和美丽程度


select Person.pname 名字,Person.psex性别,Person.pbeauty美丽程度
from Person
order by psex,pbeauty desc


先按照人名,然后按照被爱的人名的顺序,列出 所有爱情关系的施爱人,被爱人,爱情指数,受伤指 


select p1.pname 施爱人,p2.pname 被爱人,love.love_index爱情指数,love.iniury_index受伤指数
from Person p1,Person p2,love
where p1.pid =love.pid
and p2.pid=love.lovepid
order by pl.pname,p2.pname


哪些男人没有得到任何一个女人的爱?


select Person.pname没有得到爱的男人
from Person
where Person.psex='男'
and Personpid not in
(select love.lovepid
from love)


哪些男人至少爱着2个女人?


select Person.pname 至少爱着两个女人的男人
from love,Person
group by love.pid,Person.pname,Person.pid
having count(love.pid)>1
and Person.pid=love.pid
and love.pid in(
select Person.pid
from Person
where Person.psex='男')


哪个人得到了最多人的爱情?


select Person.pname 得到了最多爱的人
from Person
where Person.pid=(
select top(1) love.lovepid
from love
group by love.lovepid
order by count(*) desc)


列出所有人的姓名,以及爱他的人的数量


select Person.pname,
(select count(*) from love where love.pid=Person.pid) 爱他的人的数量
from Person
order by 2 desc


8eea9c2630f34f64841d3bb3a291db41.png


列出男人的追求者的平均美貌程度


select p1.pname 被追求者姓名,avg(p2.pbeauty) '平均美貌程度'
from love,Person p1,Person p2
where p1.pid=love.lovepid and p1.psex=’男’and p2.pid=love. pid
group by pl.pnane


列出追求者的平均爱情指数最低的男人的姓名,及其追求者的姓名和爱情指数


select p1.pname 追求者的平均爱情指数最低的男人,p2.pname 追求者,love.love_index 追求者的爱情指数
from Person p1,Person p2,love
where p1.pid=love.lovepid
and p2.pid=love.pid and p2.pid in(
select top 1 love.lovepid
from love,Person
where Person.psex='男'
and love.lovepid=Person.pid
group by love.lovepid
order by avg(love.love_index)
)
目录
相关文章
|
1月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
159 3
|
7天前
|
SQL 缓存 监控
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
本文详细解析了数据库、缓存、异步处理和Web性能优化四大策略,系统性能优化必知必备,大厂面试高频。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
|
7天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
8天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
18天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
16 2
|
23天前
|
SQL JSON Java
没有数据库也能用 SQL
SPL(Structured Process Language)是一款开源软件,允许用户直接对CSV、XLS等文件进行SQL查询,无需将数据导入数据库。它提供了标准的JDBC驱动,支持复杂的SQL操作,如JOIN、子查询和WITH语句,还能处理非标准格式的文件和JSON数据。SPL不仅简化了数据查询,还提供了强大的计算能力和友好的IDE,适用于多种数据源的混合计算。
|
25天前
|
SQL 数据库
SQL数据库基础语法入门
[link](http://www.vvo.net.cn/post/082935.html)
|
1月前
|
SQL 存储 关系型数据库
mysql 数据库空间统计sql
mysql 数据库空间统计sql
45 0
|
1月前
|
SQL 存储 监控
串口调试助手连接SQL数据库的技巧与方法
串口调试助手是电子工程师和软件开发人员常用的工具,它能够帮助用户进行串口通信的调试和数据分析
|
1月前
|
SQL 存储 数据采集
如何把问卷录入SQL数据库
将问卷数据录入SQL数据库是一个涉及数据收集、处理和存储的过程