मेरे पास SQL Server 2008 R2 तालिका है जिसकी स्कीमा संरचना निम्नानुसार है:
CREATE TABLE [dbo].[CDSIM_BE]
(
[ID] [bigint] NOT NULL,
[EquipmentID] [varchar](50) NOT NULL,
[SerialNumber] [varchar](50) NULL,
[PyrID] [varchar](50) NULL,
[MeasMode] [varchar](50) NULL,
[ReadTime] [datetime] NOT NULL,
[SubID] [varchar](15) NULL,
[ProbePosition] [float] NULL,
[DataPoint] [int] NULL,
CONSTRAINT [PK_CDSIM_BE]
PRIMARY KEY CLUSTERED ([ID] ASC, [EquipmentID] ASC, [ReadTime] ASC)
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF,
IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON,
ALLOW_PAGE_LOCKS = ON) ON [MonthlyArchiveScheme9]([ReadTime])
) ON [MonthlyArchiveScheme9]([ReadTime])
CREATE NONCLUSTERED INDEX [idx_CDSIM_BE__SubID_ProbePosition]
ON [dbo].[CDSIM_BE] ([SubID] ASC, [ProbePosition] ASC)
INCLUDE ([EquipmentID], [ReadTime], [BECorr])
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF,
SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF,
ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [MonthlyArchiveScheme9]([ReadTime])
CREATE NONCLUSTERED INDEX [IX_CDSIM_BE_ProbePosition]
ON [dbo].[CDSIM_BE] ([ProbePosition] ASC)
INCLUDE ([SerialNumber], [SubID])
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF,
SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF,
ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [MonthlyArchiveScheme9]([ReadTime])
CREATE NONCLUSTERED INDEX [IX_CSDIM_Readtime]
ON [dbo].[CDSIM_BE]([ReadTime] ASC)
INCLUDE ([EquipmentID])
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF,
SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF,
ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [MonthlyArchiveScheme9]([ReadTime])
और मैं इस सरल क्वेरी को निष्पादित कर रहा हूं:
Select Max(Id)
From dbo.CDSIM_BE
तालिका में ~ 2.5B पंक्तियाँ हैं।
क्वेरी प्लान इंडेक्स पर एक इंडेक्स स्कैन दिखाता है IX_CdSIM_BE_ProbePosition। मैं सोच रहा था कि SQL सर्वर बस क्लस्टर (और प्राथमिक) इंडेक्स का उपयोग क्यों नहीं करेगा और तुरंत तालिका में अंतिम पंक्ति पर जाएं और आईडी मान प्राप्त करें, क्योंकि यह अधिकतम होना चाहिए।
ReadTimeइसलिए यह पीके का उपयोग नहीं कर सकता जैसा कि आप वर्णन करते हैं। इसके Max(Id)लिए प्रत्येक विभाजन की खोज करनी होगी और फिर उनमें से अधिकतम को खोजना होगा। यह संभव है कि इस तरह की योजना को फिर से लिखना संभव है क्योंकि dba.stackexchange.com/a/99418/3690

select top 1 Id from dbo.CDSIM_BE order by Id descending;