[SQL智慧航行者] - 平面上最近距离

话不多说, 先看数据表信息.

数据表信息:

point_2d 表, 包含一个平面内一些点 (超过两个) 的坐标值 (x, y) .

复制代码
|x   | y  |
|----|----|
| -1 | -1 |
|  0 |  0 |
| -1 | -2 |

话不多说, 再看需求~

需求:

写一条查询语句求出这些点中的最短距离并保留2位小数。上述数据应该输出如下结果:

复制代码
+--------+
|shortest|
+--------+
|1.00    |
+--------+

结果解释:

最短距离是1,从点(-1,-1)到点(-1,-2)。

话不多说, 进行拆解~

拆解:

sql 复制代码
select 
round(sqrt(min(pow((p1.x - p2.x), 2) + pow((p1.y - p2.y), 2))), 2) as shortest
from point_2d p1, point_2d p2
where (p1.x, p1.y) <> (p2.x, p2.y)
;

效果如下:

该查询语句使用了min函数求出最小距离,pow函数计算平方,sqrt函数计算平方根,并使用round函数将结果保留2位小数。通过使用两个表别名p1和p2,可以将每个点与其他所有点进行比较,以找到最短距离。同时,使用where子句来排除点与自身的比较。结果将显示在名为shortest的列中。

最后给大家介绍一下我这边的创建数据表和插入数据的操作步骤, 想要自己测试的话, 可以参考:

sql 复制代码
CREATE TABLE point_2d (
    x INT,
    y INT
);

INSERT INTO point_2d (x, y)
VALUES (-1, -1),
       (0, 0),
       (-1, -2);

效果如下:

相关推荐
fen_fen6 小时前
Oracle建表语句示例
数据库·oracle
易营宝6 小时前
多语言网站建设避坑指南:既要“数据同步”,又能“按市场个性化”,别踩这 5 个坑
大数据·人工智能
fanstuck6 小时前
从0到提交,如何用 ChatGPT 全流程参与建模比赛的
大数据·数学建模·语言模型·chatgpt·数据挖掘
春日见6 小时前
vscode代码无法跳转
大数据·人工智能·深度学习·elasticsearch·搜索引擎
萤丰信息7 小时前
AI 筑基・生态共荣:智慧园区的价值重构与未来新途
大数据·运维·人工智能·科技·智慧城市·智慧园区
砚边数影8 小时前
数据可视化入门:Matplotlib 基础语法与折线图绘制
数据库·信息可视化·matplotlib·数据可视化·kingbase·数据库平替用金仓·金仓数据库
orange_tt8 小时前
Djiango配置Celery
数据库·sqlite
云小逸9 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
·云扬·9 小时前
MySQL Binlog落盘机制深度解析:性能与安全性的平衡艺术
android·mysql·adb
肉包_5119 小时前
两个数据库互锁,用全局变量互锁会偶发软件卡死
开发语言·数据库·c++