خانه SQL Server ایندکس در SQL Server [بخش اول] SQL Server افزایش سرعت SQL Server نوشته شده توسط: مهدی شیشه بری تاریخ انتشار: ۲۸ مرداد ۱۳۹۶ آخرین بروزرسانی: 27 دی 1403 زمان مطالعه: 9 دقیقه ۴.۷ (۱۲) ایندکس در SQL Server، شاید خواندن چنین جملهای برایتان عجیب باشد؛ ” بسیاری از توسعهدهندگان نرمافزارهای کاربردی و یا مدیران دیتابیسها اهمیتی چندانی به مقوله ایندکسها نمیدهند! ” برخی از آنها صرفا ایجاد محدودیتهای Primary Key و Unique Key را برای جداول کافی میدانند و برخی دیگر حتی نسبت به چنین موضوعی آگاهی نداشته و تنها از روی عادت همیشگی، چنین محدودیتهایی را اِعمال میکنند. بعید میدانم مخاطب این مجموعه مقالات، چنین افرادی باشند. گروه دیگری هم هستند که نسبت به موضوع ایندکسگذاری و نقش آن در افزایش عملکرد کوئریها بسیار حساس هستند اما آیا واقعا به اعتبار ایجاد ایندکسهای مناسب بر روی جداول، میتوان ادعا داشت که بر تمامی مشکلات غلبه شده و بهنهایت کارآیی در دیتابیس رسیدهایم؟ شما در این مجموعه مقالات درخواهید یافت که ایندکسگذاری مناسب فقط بخشی از مسیر بهینهسازی و افزایش کارآیی است چرا که غفلت از درست نویسی کوئری و عدم رعایت استاندارها میتواند موجب تاثیر منفی عملکرد ایندکسها شود. نکته مهم: تمامی کوئریهای این مجموعه مقالات، بر روی دیتابیس AdventureWorks2016 و در محیط نرم افزار SSMS 2016 و ۲۰۱۷ اجرا شده است. عملگر LIKE همان طور که میدانید با استفاده از عملگر LIKE میتوان بر روی مقادیر فیلدهای موجود در جداول، عملیات جستجو را بر اساس کاراکترها و یا الگوهای موردنظر انجام داد. فرض کنید از جدول Address به دنبال اطلاعات مشتریانی هستیم که یکی از نشانیهای آنها که در فیلد AddressLine1 ذخیره شده است، با کاراکتر a آغاز شده باشد. در این حالت عملگر LIKE نهایت استفاده را از ایندکسهای احتمالیِ موجود بر روی این فیلد خواهد برد. USE AdventureWorks2016 GO SET STATISTICS IO ON; SELECT AddressID, AddressLine1, AddressLine2, City, StateProvinceID, PostalCode FROM Person.Address WHERE AddressLine1 LIKE 'a%'; ایندکس در SQL Server شما با اجرای کوئری بالا و مراجعه به آمار و اطلاعات I/O از بخش Messages خواهید دید. که کمترین تعداد Page برای بازیابی چنین رکوردهایی مورد بررسی قرار گرفته شده است. همچنین با مشاهده Plan اجرایی آن نیز خواهید دید که از عملیات Index Seek استفاده شده است. در این مثال عملگر LIKE بهخوبی از قابلیتهای ایندکسها استفاده کرده است. اما چالش اساسی از زمانی آغاز خواهد شد که به دنبال مقادیری باشیم که کاراکترها یا الگوی مورد ارزیابی بهعنوان بخشی از مقادیر فیلدها باشد؛ بهعبارت دیگر آنها در ابتدای مقادیر فیلدها قرار نگرفته باشند. در این حالت دیگر مزیت مرتبسازی توسط ایندکسها چندان اهمیتی نخواهد داشت و Engine مربوط به SQL Server نمیتواند از این قابلیت استفاده کند چرا که در اینجا مرتبسازی بر اساس چپترین کاراکترِ مقادیر موجود در فیلدها انجام شده است. (توجه داشته باشید که در اینجا نوعدادهی فیلد موردنظر برابر با VARCHAR میباشد.) به عنوان مثال در کوئری زیر بهدنبال رکوردهایی هستیم که مقدار فیلد AddressLine1 آن حاوی عبارت Longbrook باشد. SELECT AddressID, AddressLine1, AddressLine2, City, StateProvinceID, PostalCode FROM Person.Address WHERE AddressLine1 LIKE '%Longbrook%'; پس از اجرای کوئری بالا و با مراجعه به آمار و اطلاعات I/O از بخش Messages خواهید دید که برای بازیابی چنین رکوردهایی تعداد Page های خوانده شده نسبت به حالت قبل بهشدت افزایش پیدا کرده است. همچنین با مشاهده Plan اجرایی آن نیز خواهید دید که دیگر خبری از عملیات Index Seek نیست و SQL Server برای بازیابی رکوردها مجبور شده است تا رکوردهای جدول را Scan کند. توجه داشته باشید که این دو مثال بر روی جدولی اجرا شده که شامل بیست هزار رکورد است. در این حالت اختلاف میان عملیاتهای Index Seek و Index Scan چندان محسوس نخواهد بود اما در دیتابیسهای بزرگ و با تعداد کاربران زیاد، نوشتن چنین کوئریهایی میتواند زمینههای بروز Locking و Blocking را فراهم کند. حال میخواهم راهکارهای مختلف برای رفع چنین مشکلی را برایتان تشریح کنم. راهحل اول در سازمان یا شرکتمان یک قانون سفت و سخت وضع کنیم که هیچکس حق ندارد به این شکل از عملگر LIKE استفاده کند وگرنه جریمه خواهد شد! بهنظر من، این قانون بیشتر از طرف مدیران کمتجربه یا کمدانش ارائه خواهد شد؛ پس اصلا منصفانه نیست. راهحل دوم بهجای اِعمال رفتارهای غیرمدیریتی بهتر است یادی کنیم از مرحوم سهراب سپهری: ” چشم ها را باید شست، جور دیگر باید دید! “ برای رفع چنین مشکلی میتوان از FULLTEXT INDEX ها استفاده کرد هر چند که بسیاری از افراد بهدلیل عدم آشنایی، از چنین قابلیتهایی استفاده نمیکنند. با استفاده از FULLTEXT INDEX کلمات، درون یک یا چند فیلد بههمراه موقعیتشان در جدول، فهرستبندی میشوند که همین موضوع در هنگام اجرای کوئری موجب افزایش سرعت شده و دیگر نیازی به پیمایش تمامی رکوردها نخواهد بود. برای این کار میبایست ابتدا یک FULLTEXT CATALOG تعریف کنیم: CREATE FULLTEXT CATALOG IndexKiller AS DEFAULT; سپس FULLTEXT INDEX ای را بر روی فیلد موردنظر تعریف میکنیم: CREATE FULLTEXT INDEX ON Person.Address(AddressLine1) KEY INDEX PK_Address_AddressID; GO در نهایت تغییراتی کوچکی را بر روی کوئری انجام میدهیم. در اینجا میبایست در بخش WHERE یکی از توابع مربوط به FULLTEXT INDEX را با عنوان CONTAINS مورد استفاده قرار دهیم. SELECT AddressID, AddressLine1, AddressLine2, City, StateProvinceID, PostalCode FROM Person.Address WHERE CONTAINS (AddressLine1,'Longbrook'); پس از اجرای کوئری و مشاهده آمار و اطلاعات I/O خواهید دید که خوانش تعداد Page ها به مقدار قابل توجهی کاهش یافته است. همچنین با مراجعه به Plan اجرایی کوئری بالا میبینید که از عملیات Index Seek استفاده شده است. یشنهاد میکنیم برای درک بهتر مفاهیم کوئری نویسی را مطالعه کنید. مجددا این بار هر دو کوئری را با هم اجرا میکنیم. کوئری اول با استفاده از عملگر LIKE و کوئری دوم با استفاده از قابلیت FULLTEXT Index عملیات جستجو را انجام خواهند داد. افراد علاقهمند میتوانند با مطالعه مقاله پرکاربردترین دستورات SQL Server، دانش خود را در زمینه کوئرینویسی گسترش دهند. -- Query with LIKE operator SELECT AddressID, AddressLine1, AddressLine2, City, StateProvinceID, PostalCode FROM Person.Address WHERE AddressLine1 LIKE '%Longbrook%'; -- Query with LIKE operator SELECT AddressID, AddressLine1, AddressLine2, City, StateProvinceID, PostalCode FROM Person.Address WHERE CONTAINS (AddressLine1,'Longbrook'); در تصویر زیر مقایسه آمار و اطلاعات I/O و میزان Cost مربوط به Plan اجرایی هر دو کوئری نمایش داده شده است و شما میبینید که چگونه با استفاده از قابلیت FULLTEXT INDEX زمینههای افزایش عملکرد اجرایی کوئری و کاهش استفاده از منابع را فراهم کردهایم. سخن پایانی ایندکس در SQL Server در این مقاله با استفاده از عملگر LIKE میتوان بر روی مقادیر فیلدهای موجود در جداول، عملیات جستجو را بر اساس کاراکترها و یا الگوهای موردنظر انجام داد. بررسی خواهیم کرد، ما در نیک آموز منتظر نظرات ارزشمند شما درباره این مقاله هستیم. چه رتبه ای میدهید؟ میانگین ۴.۷ / ۵. از مجموع ۱۲ اولین نفر باش دانلود مقاله ایندکس در SQL Server [بخش اول] فرمت PDF 7 صفحه حجم 1 مگابایت دانلود مقاله معرفی نویسنده معرفی محصول مسعود طاهری دوره ۳ در ۱ آموزش performance tuning در SQL Server 6.700.000 تومان مقالات مرتبط ۰۶ آذر زبان های برنامه نویسی مقایسه بهترین زبانهای برنامهنویسی ۲۰۲۵ ۰۵ آذر زبان های برنامه نویسی زبان گو (GO) و بررسی مزایا و کاربرد این زبان برنامه نویسی ۳۰ آبان هوش تجاری power bi چیست و چرا تجزیه و تحلیل دادهها در کسب و کار اهمیت دارد؟ ۱۳ آبان اکسل آموزش تبدیل ورد به اکسل با روش های ساده و کاربردی تیم فنی نیک آموز دیدگاه کاربران لغو پاسخ دیدگاه نام و نام خانوادگی ایمیل ذخیره نام، ایمیل و وبسایت من در مرورگر برای زمانی که دوباره دیدگاهی مینویسم. موبایل برای اطلاع از پاسخ لطفاً مرا با خبر کن ثبت دیدگاه Δ قاسمی ۰۷ / ۰۶ / ۹۶ - ۰۵:۲۸ عالی بود. فقط فکز میکنم تصویر دوم (مربوط به کوئری LIKE ‘%Longbrook%’;) اشتباه گذاشته شده، و عکس مربوط به کوئری فول-تکست هم همان است. (آدرس هر دو https://nikamooz.com/wp-content/uploads/2017/08/kill_index_3-e1503163450575.jpg است) پاسخ به دیدگاه حسین ۰۷ / ۰۶ / ۹۶ - ۰۵:۰۷ سلام آیا امکان استفاده از قابلیت FULLTEXT Index در جستجو هایی که روی View انجام میشه، امکان پذیر هست ؟ پاسخ به دیدگاه مهدی شیشه بری ۰۷ / ۰۶ / ۹۶ - ۰۹:۱۴ دوست عزیز به لینک زیر مراجعه کنید: https://goo.gl/gS1m2N پاسخ به دیدگاه حسین ۰۷ / ۰۶ / ۹۶ - ۰۵:۰۷ سلام آیا امکان استفاده از قابلیت FULLTEXT Index در جستجو هایی که روی View انجام میشه، امکان پذیر هست ؟ پاسخ به دیدگاه مهدی شیشه بری ۰۷ / ۰۶ / ۹۶ - ۰۹:۱۴ دوست عزیز به لینک زیر مراجعه کنید: https://goo.gl/gS1m2N پاسخ به دیدگاه تورج اسکویی لر ۰۴ / ۰۶ / ۹۶ - ۰۸:۵۹ عالی بود سپاس پاسخ به دیدگاه تورج اسکویی لر ۰۴ / ۰۶ / ۹۶ - ۰۸:۵۹ عالی بود سپاس پاسخ به دیدگاه lotfi.engin ۰۲ / ۰۶ / ۹۶ - ۰۵:۵۸ دستتون درد نکنه منتظر قسمت های بعدی هستیم پاسخ به دیدگاه عليرضا ۳۰ / ۰۵ / ۹۶ - ۰۵:۵۹ در متن ها نوشته شده index seek ولی در عکس index scan نشان داده میشود پاسخ به دیدگاه مهدی شیشه بری ۳۱ / ۰۵ / ۹۶ - ۰۷:۰۸ سلام ممنون از دقت بالای شما. اگر اولین کوئری را اجرا کنید، دقیقا در پلن اجرایی آن خواهید دید که از عملیات Index Seek استفاده شده است. فکر میکنم تصویر دومین پلن اجرایی در تصویر اول تکرار شده است. با عرض پوزش اصلاح خواهد شد. ضمنا تمامی اسکریپتهای این مقاله و قسمتهای بعدی را علاوه بر دیتابیس AdventureWorks2016 بر روی AdventureWorks2014 هم میتوانید اجرا کنید. پاسخ به دیدگاه آرزو محمدزاده ۲۰ / ۰۵ / ۰۰ - ۰۹:۰۴ با سلام و وقت بخیر شما می توانید با استفاده از این DM View سیستمی و فیلد percent_complete در صد پیشرفت رو بررسی کنید. sys.dm_exec_requests برای استفاده از این DM View به لینک زیر مراجعه کنید https://docs.microsoft.com/en-us/sql/relational-databases/system-dynamic-management-views/sys-dm-exec-requests-transact-sql?view=sql-server-ver15 پاسخ به دیدگاه آرزو محمدزاده ۲۹ / ۰۸ / ۹۶ - ۱۲:۴۵ با سالم سپاس از همراهی شما لینک دانلود تست شد و بدون خطا فایل قابل دانلود است ولی برای سهولت شما فایل برای شما ایمیل گردید. پاسخ به دیدگاه آرزو محمدزاده ۲۹ / ۰۸ / ۹۶ - ۱۲:۴۵ با سالم سپاس از همراهی شما لینک دانلود تست شد و بدون خطا فایل قابل دانلود است ولی برای سهولت شما فایل برای شما ایمیل گردید. پاسخ به دیدگاه مهدی شیشه بری ۳۱ / ۰۵ / ۹۶ - ۰۷:۰۸ سلام ممنون از دقت بالای شما. اگر اولین کوئری را اجرا کنید، دقیقا در پلن اجرایی آن خواهید دید که از عملیات Index Seek استفاده شده است. فکر میکنم تصویر دومین پلن اجرایی در تصویر اول تکرار شده است. با عرض پوزش اصلاح خواهد شد. ضمنا تمامی اسکریپتهای این مقاله و قسمتهای بعدی را علاوه بر دیتابیس AdventureWorks2016 بر روی AdventureWorks2014 هم میتوانید اجرا کنید. پاسخ به دیدگاه 1 2