DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: webb123
今日帖子: 40
在线用户: 23
导航: 论坛 -> 数据库专区 斑竹:liumazi,waterstone  
作者:
男 xbbtzhao (itv) ★☆☆☆☆ -
盒子活跃会员
2018/9/25 12:49:22
标题:
MSSQL 2008一条件语句CUP 占用100%,请帮忙优化 浏览:1598
加入我的收藏
楼主: MSSQL 2008一条件语句CUP 占用100%,请帮忙优化
同一设备,不同时间有N条记录,查询某些设备最近日期的一条记录

select * from  Glog2 a  where a.Gdwork=@MGdwork and not exists(select 1 from Glog2  where Gdcode=a.Gdcode and Gdclass=a.Gdclass and Gdwork=a.Gdwork and Gdate>a.Gdate)
还能怎么写,占用资源少些???
----------------------------------------------
free
作者:
男 xbbtzhao (itv) ★☆☆☆☆ -
盒子活跃会员
2018/9/25 13:01:47
1楼: GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[Glog2](
  [ID] [bigint] IDENTITY(1,1) NOT NULL,
  [Gdcode] [int] NULL,
  [Gdclass] [int] NULL,
  [Gdtype] [int] NULL,
  [Gdwork] [varchar](20) NULL,
  [Gdname] [varchar](20) NULL,
  [p1] [varchar](20) NULL,
  [p2] [varchar](20) NULL,
  [p3] [varchar](20) NULL,
  [P4] [varchar](20) NULL,
  [Gpcname] [varchar](20) NULL,
  [Gdate] [datetime] NULL
) ON [PRIMARY]
GO
SET ANSI_PADDING OFF
GO

GO
SET IDENTITY_INSERT [dbo].[Glog2] ON
INSERT [dbo].[Glog2] ([ID], [Gdcode], [Gdclass], [Gdtype], [Gdwork], [Gdname], [p1], [p2], [p3], [P4], [Gpcname], [Gdate]) VALUES (2759, 1, 2, 1, N'C01', N'2-1', N'', N'', N'', N'', N'', CAST(0x0000A8DD00D9AC32 AS DateTime))
INSERT [dbo].[Glog2] ([ID], [Gdcode], [Gdclass], [Gdtype], [Gdwork], [Gdname], [p1], [p2], [p3], [P4], [Gpcname], [Gdate]) VALUES (2760, 2, 1, 3, N'C01', N'1-2', N'', N'', N'', N'', N'', CAST(0x0000A96600D9CBCE AS DateTime))
INSERT [dbo].[Glog2] ([ID], [Gdcode], [Gdclass], [Gdtype], [Gdwork], [Gdname], [p1], [p2], [p3], [P4], [Gpcname], [Gdate]) VALUES (2761, 3, 1, 6, N'C01', N'1-3', N'', N'', N'', N'', N'', CAST(0x0000A96600D916BE AS DateTime))
INSERT [dbo].[Glog2] ([ID], [Gdcode], [Gdclass], [Gdtype], [Gdwork], [Gdname], [p1], [p2], [p3], [P4], [Gpcname], [Gdate]) VALUES (2762, 7, 2, 1, N'D01', N'2-7', N'', N'', N'', N'', N'', CAST(0x0000A96600A85F33 AS DateTime))
INSERT [dbo].[Glog2] ([ID], [Gdcode], [Gdclass], [Gdtype], [Gdwork], [Gdname], [p1], [p2], [p3], [P4], [Gpcname], [Gdate]) VALUES (2763, 1, 2, 1, N'C01', N'2-1', N'', N'', N'', N'', N'', CAST(0x0000A9120024DA28 AS DateTime))
INSERT [dbo].[Glog2] ([ID], [Gdcode], [Gdclass], [Gdtype], [Gdwork], [Gdname], [p1], [p2], [p3], [P4], [Gpcname], [Gdate]) VALUES (2764, 7, 2, 1, N'D01', N'2-7', N'', N'', N'', N'', N'', CAST(0x0000A96600DA55F3 AS DateTime))
SET IDENTITY_INSERT [dbo].[Glog2] OFF
----------------------------------------------
free
作者:
男 zhahongyi (如风) ★☆☆☆☆ -
普通会员
2018/9/25 13:27:44
2楼: SELECT TOP 1 * FROM glog2 WHERE Gdwork = 'C01' ORDER BY gdate desc
----------------------------------------------
-
作者:
男 hdcopy (hdcopy) ★☆☆☆☆ -
普通会员
2018/9/25 14:22:43
3楼: 很多种写法,度娘里满地都是,例如
通用的
select * from xxx where id in (select max(id) from xxx where .... group by ...)
专用的 top 1
装B的统计开窗函数
----------------------------------------------
-
作者:
男 xbbtzhao (itv) ★☆☆☆☆ -
盒子活跃会员
2018/9/26 12:51:31
4楼: select top 1 * from Glog2 where gdclass=2 order by gdate desc
select y.* from
(select max(a.Gdate) Gdate,Gdwork from dbo.Glog2 a where a.Gdwork='C01' group by Gdwork) x,dbo.Glog2 y
where x.Gdwork=y.Gdwork and x.Gdate=y.Gdate

都只显示了一行数据,不对
----------------------------------------------
free
作者:
男 xbbtzhao (itv) ★☆☆☆☆ -
盒子活跃会员
2018/9/26 15:20:46
5楼: with tmp as( select (row_number() over(partition by Gdcode order by gdate desc)) as num ,* from Glog2 where Gdcode in (SELECT DISTINCT Grcode FROM GrList where Grgroup='G1')) select * from tmp where num=1
问题解决
----------------------------------------------
free
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行82.03125毫秒 RSS