मुझे टेम्पोरल डेटाबेस के डिज़ाइन से परेशानी हो रही है। मुझे यह जानने की ज़रूरत है कि किसी स्टोर के लिए किसी भी समय सीमा के लिए मेरे पास केवल एक ही सक्रिय रिकॉर्ड कैसे है। मैंने इस जवाब को पढ़ा है , लेकिन मुझे डर है कि मैं अपने सिर को लपेट नहीं सकता कि ट्रिगर कैसे काम करेगा। विशेष रूप से, मैं अपने मौजूदा में ट्रिगर कैसे काम करूंगा जो रिकॉर्ड को अपडेट करने से रोकता है, और इसके बजाय एक नया रिकॉर्ड सम्मिलित करता है। मेरी वास्तविक समस्या यह है कि मुझे नहीं पता कि एक दुकान को एक से अधिक प्रभावी तारीख होने से कैसे रोका जाए जब समाप्त तिथि शून्य हो। (यानी एक स्टोर के लिए 2 सक्रिय रिकॉर्ड को रोकना)।
यह मेरे पास है, लेकिन यह मुझे एक अलग प्रभावी तिथि के साथ स्टोर के लिए एक नया रिकॉर्ड सम्मिलित करने की अनुमति देता है।
तालिका परिभाषा:
/****** Object: Table [PCR].[Z_STORE_TEAM] Script Date: 05/09/2014 13:05:57 ******/
IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[Z_STORE_TEAM]') AND type in (N'U'))
DROP TABLE [Z_STORE_TEAM]
GO
IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[Z_STORE_TEAM]') AND type in (N'U'))
BEGIN
CREATE TABLE [Z_STORE_TEAM](
[STORENUM] [int] NOT NULL,
[TEAM] [varchar](10) NULL,
[EFFECTIVE] [date] NOT NULL,
[FINISHED] [date] NULL,
PRIMARY KEY CLUSTERED
(
[STORENUM] ASC,
[EFFECTIVE] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
END
GO
नमूना डेटा:
INSERT [Z_STORE_TEAM] ([STORENUM], [TEAM], [EFFECTIVE], [FINISHED]) VALUES (1, N'1', CAST(0x01380B00 AS Date), CAST(0x81380B00 AS Date))
INSERT [Z_STORE_TEAM] ([STORENUM], [TEAM], [EFFECTIVE], [FINISHED]) VALUES (1, N'2', CAST(0x81380B00 AS Date), NULL)
INSERT [Z_STORE_TEAM] ([STORENUM], [TEAM], [EFFECTIVE], [FINISHED]) VALUES (2, N'1', CAST(0x01380B00 AS Date), NULL)
INSERT [Z_STORE_TEAM] ([STORENUM], [TEAM], [EFFECTIVE], [FINISHED]) VALUES (2, N'2', CAST(0x20380B00 AS Date), NULL)
अपडेट ट्रिगर के बजाय:
CREATE TRIGGER [tr_ZStoreTeam_update]
ON [Z_STORE_TEAM]
INSTEAD OF UPDATE
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for trigger here
INSERT INTO PCR.Z_STORE_TEAM(STORENUM,TEAM,EFFECTIVE)
SELECT I.STORENUM,I.TEAM,GETDATE() AS EFFECTIVE
FROM inserted I
INNER JOIN PCR.Z_STORE_TEAM ST
ON I.STORENUM = ST.STORENUM
UPDATE ST
SET FINISHED = GETDATE()
FROM PCR.Z_STORE_TEAM ST
INNER JOIN inserted I
ON ST.STORENUM = I.STORENUM
AND ST.EFFECTIVE = I.EFFECTIVE
END
GO