SQL Server 多表联合查询取最新一条数据

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 所有的SQL语句如下:create database David;use David--雨量站表create table RainSite( ID int not null...

所有的SQL语句如下:

create database David;
use David
--雨量站表
create table RainSite
(
   ID int not null primary key identity(1,1),
   SiteCode varchar(8) not null,
   SiteName varchar(20) not null,
   Latitute decimal(10,6) not null,
   Longitute decimal(10,6) not null
)
--插入雨量站测试数据
insert into RainSite values('34242580','AA',117.377656,29.990671);
insert into RainSite values('34242581','BB',117.387761,29.924643);
insert into RainSite values('34242582','CC',117.397844,29.935675);
insert into RainSite values('34242583','DD',117.437625,29.950649);

--水位站
create table WaterSite
(
   ID int not null primary key identity(1,1),
   SiteCode varchar(8) not null,
   SiteName varchar(20) not null,
   Latitute decimal(10,6) not null,
   Longitute decimal(10,6) not null
)
--插入水位站测试数据
insert into WaterSite values('34242584','EE',117.477656,29.690671);
insert into WaterSite values('34242585','FF',117.587761,29.324643);
insert into WaterSite values('34242586','GG',117.697844,29.835675);
insert into WaterSite values('34242587','HH',117.737625,29.550649);

--站点类型表
create table SiteType
(
    ID int not null primary key identity(1,1),
    SiteTypeName varchar(20)
)

--插入站点类型数据
insert into SiteType values('水位');
insert into SiteType values('雨量');

--预警记录表
create table WarningForcast
(
   ID int not null primary key identity(1,1),
   SiteTypeID int not null,
   SiteCode varchar(8) not null,
   SiteName varchar(20) not null,
   ForecastTime datetime not null,
   ForecastContent text
)

--插入预警记录数据
insert into WarningForcast values(1,'34242581','BB','2012-06-05 12:20:25','发生险情,请相关单位注意!');
insert into WarningForcast values(1,'34242581','BB','2012-06-06 15:50:25','发生险情,请相关单位注意!');
insert into WarningForcast values(2,'34242586','GG','2012-06-05 12:30:25','发生险情,请相关单位注意!');
insert into WarningForcast values(2,'34242586','GG','2012-06-05 18:40:25','发生险情,请相关单位注意!');
insert into WarningForcast values(2,'34242587','HH','2012-06-05 19:20:25','发生险情,请相关单位注意!');
insert into WarningForcast values(1,'34242583','DD','2012-06-05 15:50:25','发生险情,请相关单位注意!');

--需求,要取出预警记录表中的三天内不同站点的最新一条记录及对应的水位或雨量站点的经度和纬度信息

select t.ID,t.SiteTypeID,t.SiteCode,t.SiteName,t.ForecastTime,t.ForecastContent
,t1.SiteCode,t1.SiteName,t1.Latitute,t1.Longitute
from 
WarningForcast t,
(
   select * from RainSite
   union
   select * from WaterSite
) t1
where t.SiteCode=t1.SiteCode and ForecastTime in 
(
   select MAX(ForecastTime) from WarningForcast where SiteCode=t.SiteCode
)
and ForecastTime between DATEADD(DAY,-3,GETDATE()) and GETDATE()
order by t.ForecastTime desc;

--水位站表
select * from WaterSite;

--雨量站表
select * from RainSite;


实际效果如下:


相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
3月前
|
SQL 安全 前端开发
Web学习_SQL注入_联合查询注入
联合查询注入是一种强大的SQL注入攻击方式,攻击者可以通过 `UNION`语句合并多个查询的结果,从而获取敏感信息。防御SQL注入需要多层次的措施,包括使用预处理语句和参数化查询、输入验证和过滤、最小权限原则、隐藏错误信息以及使用Web应用防火墙。通过这些措施,可以有效地提高Web应用程序的安全性,防止SQL注入攻击。
100 2
|
3月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
115 4
|
4月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
4月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
4月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
4月前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
787 4
|
4月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
165 0
|
5月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
6月前
|
SQL 安全 Java
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
605 0
|
7月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
94 6