Database Design Question: Treating GUID's around the place -


यहाँ एक सरल उदाहरण है।

  UserDetails (UserID INT UserGUID UNIQUEIDENTIFIER नाम VARCHAR (50) युग आईएनटी) यूज़रराइटिंग (यूजरआईडी आईएनटी रेटिंग आईएनटी डेट डेटइटम) यूज़रवॉट (यूजरआईडी आईएनटी वोट आईएनटी डेटेटटाइम)   <पी> युजरग्रीड केवल मुख्य टेबल में मौजूद है। 

इसमें आवेदन परत केवल GUID के आसपास पार्स किए जाते हैं, INTS कभी नहीं। यह प्रतिद्वंद्वियों को मेरी साइट पर कुछ प्रमुख नंबरों (जैसे उपयोगकर्ता गिनती) की अनुमान लगाने से रोकने के लिए है।

तालिका के साथ संबंधित SPROCS में UserRatings और UserVotes, मुझे UserID को सेट करना होगा और यह UserGUID पर सेट करना होगा जो हर प्रक्रिया की शुरुआत में वापस पार्स हो रहा है।

यह केवल उपयोगकर्ता तालिका के लिए नहीं बल्कि प्रत्येक अन्य ऑब्जेक्ट के लिए होता है जिसमें मुख्य टेबल और ब्रंचयुक्त टेबल होते हैं, इसलिए इन DECLARE / SET प्रकार के टन हैं

क्या यह एक अच्छी डिजाइन है?

<पी > उपयोगकर्तागत केवल मुख्य तालिका में मौजूद है एप्लिकेशन परत में केवल GUID के अंश हैं, कभी भी INTS नहीं। यह प्रतिद्वंद्वियों को मेरी साइट पर कुछ प्रमुख नंबरों (जैसे उपयोगकर्ता गिनती) जैसे अनुमान लगाने से रोकने के लिए है।

मेरे लिए काफी उचित लगता है।

इसमें UserRatings और UserVotes तालिकाओं से संबंधित SPROCS, मुझे UserID के आधार पर उपयोगकर्ता आईडी को सेट करना होगा और प्रत्येक प्रक्रिया की शुरुआत में वापस पार्स किया जा रहा है।

आप एक दृश्य स्पैन को भी परिभाषित कर सकते हैं UserDetails + UserRatings , साथ ही साथ UserDetails + UserVotes (या एक बार में सभी तीन सारणी), जिसमें UserDetails तालिका से GUID शामिल है यह तालिकाओं को क्वेरी करने में आसान होता है और आपको सबसे पहले GUID से आईडी निकालने और प्रश्न में तालिका को क्वेरी करने के लिए उपयोग नहीं करना होगा।

अपडेट: यदि आप उदा। बार-बार UserRatings क्वेरी करने की आवश्यकता है, आप इस तरह एक दृश्य बना सकते हैं:

  बनाओ dbo.UserRatingsWith चयन के रूप में चयन करें यूजर। यूजरगुइड, उद। नाम, ud.Age, Ur.UserID, ur.Rating, ur.Date FROM dbo.UserDetails ud INNER JOIN dbo.UserRatings ur on ur.UserID = ud.UserID  

और उसके बाद आप उस दृश्य से बिना चयन कर सकते हैं एक अलग SELECT पहले चलाना:

  SELECT UserID, नाम, रेटिंग, दिनांक से दिनांक dbo.UserRatingsWithDetailsWhere उपयोगकर्ताग्यूड = @SomeGuidValue  

सही इंडेक्स के साथ ( UserRatings में विदेशी कुंजी फ़ील्ड पर), यह बहुत ही अत्यधिक प्रदर्शन करने वाला जॉइन है - यहां कोई चिंता नहीं है!


Comments

Popular posts from this blog

c# - sqlDecimal to decimal clr stored procedure Unable to cast object of type 'System.Data.SqlTypes.SqlDecimal' to type 'System.IConvertible' -

Calling GetGUIThreadInfo from Outlook VBA -

Obfuscating Python code? -