मेरे पास मैंने प्राथमिक कुंजी (और संकुल अनुक्रमणिका) को डेटाबेस विकास पक्ष के लिए नया मुझे केवल मूल एसक्यूएल पता है यह भी सुनिश्चित नहीं है कि SQL सर्वर 200,000 पंक्तियां जल्दी से संभाल सकता है पूरी गतिशील प्रक्रिया जिस पर आप देख सकते हैं किसी को भी इस तरह से बड़ी पंक्तियाँ संभालने का सामना करना पड़ा? मैं यहां प्रदर्शन को कैसे सुधारूं? अच्छा, जब तक कि मुझे कुछ याद आ रही है (जैसे डुप्लिकेट पंक्तियाँ?) आप के रूप में आप चयन सूची में सभी क्षेत्रों द्वारा समूहबद्ध हैं, और आप इसके अलावा, आपको तालिका में उसमें सम्मिलित होने वाले कॉलमों वाले टेबल्स पर होना चाहिए। उदाहरण के लिए, मैं टेबल पर एक इंडेक्स बनाऊँगा जिसमें कॉलम के साथ मरीज (TenantId, PersonId, ResponsiblePersonId, AddBy ) शामिल कॉलम के साथ (रोगी आईडी, रोगी पहचानकर्ता) Patient & amp; में 200,000 पंक्तियाँ हैं
व्यक्ति तालिका, और क्वेरी को निष्पादित करने के लिए 30 सेकंड लगते हैं।
व्यक्ति तालिका में परिभाषित किया है
PersonId और
PatientId में
Patient तालिका में मेरी प्रक्रिया के प्रदर्शन में सुधार करने के लिए मैं यहाँ क्या कर सकता हूं?
DECLARE @ वापसी_वल्यूएट, @ कुटिरॉव्स बिल्टीन्ट, @ इंट पेज्स इंट, @TenantId int, @IntItems int, @page int SET @TenantId = 1 SET @unitItems = 20 सेट @page = 1 घोषित @PatientSearch टेबल ([PatientId] [bigint] नहीं NULL, [PatientIdentifier] [nvarchar] (50) शून्य, [PersonNumber] [nvarchar] (20) शून्य, [FIRSTNAME] [nvarchar] (100 ) नल नहीं, [अंतिम नाम] [नर्वचर] (100) नहीं नल, [रिस्फास्टनाम] [नवर्वचर] (100) नहीं नल, [रिस्लाइटनाम] [नर्वचर] (100) नहीं नल, [एडफस्टनाम] [नर्वचर] (100) नहीं Null, [AddLastName] [nvarchar] (100) नहीं नल, [पता] [नववर्कर] (255) नल, [शहर] [नर्वचर] (50) नल, [राज्य] [नर्वचर] (50) नल, [ज़िपकोड] [nvarchar] (20) शून्य, [देश] [nvarchar] (50) शून्य, [RowNumber] [bigint] शून्य) में @PatientSearch चयन PAT.PatientId, PAT.PatientIdentifier, PER.PersonNumber, PER.FirstName, प्रति डालें। LastName, RES_PER.FirstName AS ResFirstName, RES_PER.LastName AS ResLastName, ADD_PER.प्रथम नाम ASFirstName, ADD_PER.LastName AS AddLastName, PER.Address, PER.City, PER.State, PER.ZipCode, PER.Country, ROW_NUMBER () से अधिक (PAT.PatientId DESC द्वारा आदेश) के रूप में RowNumber dbo.Patient से PAT अंदरूनी के रूप में पर के अनुसार प्रति dbo.Person शामिल हों PAT.PersonId = PER.PersonId अंदरूनी dbo.Person के शामिल होते ही RES_PER पर PAT.ResponsiblePersonId = RES_PER.PersonId अंदरूनी dbo.Person के शामिल होते ही ADD_PER पर PAT.AddedBy = ADD_PER.PersonId अंदरूनी PAT.PatientId पर बी के रूप में शामिल dbo.Booking = बी .PatientId कहां PAT.TenantId = @TenantId और B.CategoryId = @CategoryId PAT.PatientId, PAT.PatientIdentifier, PER.PersonNumber, PER.FirstName, PER.LastName, RES_PER.FirstName, RES_PER.LastName, ADD_PER.FirstName द्वारा समूह, ADD_PER.ListName, PER.Address, PER.City, PER.State, PER.ZipCode, प्रति। देश; SELECT @unitRows = @@ ROWCOUNT, @ यूनिटपृष्ठ = (@ कुटीर / / निट आईटम्स) + 1; का चयन करें * से पेटेंट खोज के रूप में आईटी जहां रोनांबर बीते (@ पेज - 1) * @unitItems + 1 और @unitItems * @page
GROUP BY
ग्रुप को निकाल सकते हैं द्वारा PAT.PatientId, PAT.PatientIdentifier, PER.PersonNumber, PER.FirstName, PER.LastName, RES_PER.FirstName, RES_PER.LastName, ADD_PER.FirstName, ADD_PER.LastName, PER.Address, PER.City, PER.State, प्रति । ज़िपकोड, प्रति देश
PAT.PatientId
No comments:
Post a Comment