SQL Server 多表聯合查詢取最新一條資料
所有的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;
實際效果如下:
相關文章
- 多表聯合查詢 - 基於註解SQLSQL
- JPA 之 多表聯合查詢
- sql 多組條資料取最新的一條資料SQL
- SQL Server 查詢資料庫中所有表資料條數SQLServer資料庫
- jpa動態查詢與多表聯合查詢
- SQL優化之多表關聯查詢-案例一SQL優化
- mybatis多表聯合查詢的寫法MyBatis
- SQL Server 跨資料庫查詢SQLServer資料庫
- 深入sql多表差異化聯合查詢的問題詳解SQL
- SQL查詢的:子查詢和多表查詢SQL
- SQL 三表聯合查詢SQL
- 01-sql-聯合查詢SQL
- postgresql 多條記錄合併一條,或取最新的一條資料SQL
- 20240719資料庫關聯查詢、條件查詢資料庫
- JPA多表關聯查詢
- MYSQL學習筆記24: 多表查詢(聯合查詢,Union, Union All)MySql筆記
- 一條SQL完成跨資料庫例項Join查詢SQL資料庫
- SQL Server實戰四:查詢資料庫的資料SQLServer資料庫
- Oracle\MS SQL Server Update多表關聯更新OracleSQLServer
- 34. 過濾條件、多表查詢、子查詢
- 最新!SQL Server 2019將結合Spark建立統一資料平臺!SQLServerSpark
- MySQL資料庫基礎——多表查詢:子查詢MySql資料庫
- SQL Server解惑——查詢條件IN中能否使用變數SQLServer變數
- sql 多表關聯刪除表資料SQL
- Mybatis【15】-- Mybatis一對一多表關聯查詢MyBatis
- SQL Server資料庫————模糊查詢和聚合函式SQLServer資料庫函式
- SQL server資料庫表碎片比例查詢語句SQLServer資料庫
- 概括SQL Server實時查詢Oracle資料庫WSSQLServerOracle資料庫
- springDataJpa多表級聯查詢(@ManyToOne @OneToOne)Spring
- MyBatisPlus怎麼多表關聯查詢?MyBatis
- mysql中的多表關聯查詢MySql
- 如何做多表關聯查詢
- Android—Room資料庫多表查詢(Relationships)AndroidOOM資料庫
- SQL Server中Table字典資料的查詢SQL示例程式碼SQLServer
- 教你用一條SQL搞定跨資料庫查詢難題SQL資料庫
- 多表查詢
- onethinkphp 如何做多表關聯查詢PHP
- SQL:查詢每個類別最新的5條記錄SQL
- SQL面試題 三(單表、多表查詢)SQL面試題