طراحی و مدیریت Database Diagrams در SQL Server Management Studio SSMS

طراحی و مدیریت آسان Database Diagrams در SQL Server Management Studio (SSMS)

ساخت Database Diagrams در SQL Server Management Studio (SSMS) ابزاری قدرتمند برای درک، مستندسازی و طراحی بصری ساختار پایگاه داده شماست. این نمودارها به شما کمک می‌کنند تا جداول، ستون‌ها، کلیدهای اصلی و خارجی، و روابط بین آن‌ها را به وضوح مشاهده کنید. این راهنما به شما نشان می‌دهد که چگونه یک دیاگرام پایگاه داده حرفه‌ای و خوانا ایجاد کنید.

ابتدا، برنامه SQL Server Management Studio (SSMS) را باز کرده و به نمونه (instance) SQL Server خود متصل شوید. در بخش Object Explorer، دیتابیسی را که قصد دارید برای آن دیاگرام ایجاد کنید، پیدا کرده و گسترش دهید. سپس، گره “Database Diagrams” را گسترش دهید.

اگر اولین بار است که برای این دیتابیس دیاگرام ایجاد می‌کنید، ممکن است SSMS از شما بپرسد که آیا مایلید اشیاء پشتیبانی دیاگرام را ایجاد کند. برای ادامه کار، روی “Yes” کلیک کنید. این اشیاء جداول سیستمی هستند که اطلاعات مربوط به دیاگرام‌ها را ذخیره می‌کنند و برای عملکرد صحیح ابزار دیاگرام‌سازی ضروری هستند.

برای شروع ساخت یک دیاگرام جدید، روی گره “Database Diagrams” راست‌کلیک کرده و گزینه “New Database Diagram” را انتخاب کنید. با این کار پنجره “Add Table” باز می‌شود که لیستی از تمام جداول موجود در دیتابیس شما را نمایش می‌دهد. از این پنجره، جداولی را که می‌خواهید در دیاگرام خود نمایش دهید، انتخاب کنید. می‌توانید چندین جدول را با نگه داشتن کلید Ctrl و کلیک روی آن‌ها، انتخاب کنید.

پس از انتخاب جداول مورد نظر (مانند Customers، Orders، Products)، روی دکمه “Add” و سپس “Close” کلیک کنید. جداول انتخابی روی سطح دیاگرام ظاهر می‌شوند. می‌توانید آن‌ها را بکشید و رها کنید تا به بهترین شکل سازماندهی شوند. SSMS به طور خودکار روابط کلید خارجی (Foreign Key) موجود بین جداول را شناسایی کرده و خطوط ارتباطی را نمایش می‌دهد.

**ایجاد روابط جدید در دیاگرام (در صورت عدم وجود کلید خارجی):**

اگر دیتابیس شما روابط کلید خارجی را از قبل تعریف نکرده است یا می‌خواهید یک رابطه جدید بصری ایجاد کنید، این کار به راحتی با کشیدن و رها کردن قابل انجام است. به عنوان مثال، برای ایجاد یک رابطه بین Category ID در جدول Categories (کلید اصلی) و Category ID در جدول Products (کلید خارجی)، ستون Category ID از جدول Categories را انتخاب کرده و آن را روی ستون Category ID در جدول Products بکشید و رها کنید.

پنجره “Tables and Columns” ظاهر می‌شود. در این پنجره، SSMS به شما امکان می‌دهد تا جزئیات رابطه را تأیید کنید. مطمئن شوید که ستون‌های کلید اصلی و خارجی به درستی نگاشت شده‌اند، سپس روی “OK” کلیک کنید. در نهایت، پنجره “Change Confirmation” ظاهر می‌شود که از شما می‌خواهد تغییرات را تأیید کنید. با کلیک بر روی “Yes”، رابطه در دیتابیس شما ایجاد و در دیاگرام نمایش داده می‌شود.

**ذخیره Database Diagrams:**

برای ذخیره دیاگرام خود، می‌توانید از منوی “File” گزینه “Save Diagram1” (یا هر نام پیش‌فرض دیگر) را انتخاب کنید، یا از کلیدهای میانبر Ctrl+S استفاده کنید. SSMS از شما می‌خواهد تا یک نام برای دیاگرام خود وارد کنید (مثلاً SalesSchema). پس از وارد کردن نام و کلیک روی “OK”، دیاگرام شما ذخیره شده و در زیر گره “Database Diagrams” در Object Explorer قابل دسترسی خواهد بود. می‌توانید هر زمان با دوبار کلیک بر روی نام آن، دیاگرام را باز کرده و ویرایش کنید.

**قابلیت‌های اضافی در دیاگرام:**

در دیاگرام SSMS، می‌توانید نمای جداول را تغییر دهید. با راست‌کلیک روی یک جدول، از گزینه “Table View” می‌توانید نماهای مختلفی مانند “Standard” (نمایش تمام ستون‌ها و جزئیات)، “Column Names” (فقط نام ستون‌ها)، “Keys” (فقط کلیدها)، یا “Name Only” (فقط نام جدول) را انتخاب کنید. این قابلیت‌ها به شما کمک می‌کنند تا دیاگرام خود را برای اهداف مختلف بهینه کنید.

همچنین، برای افزودن توضیحات یا یادداشت‌های متنی به دیاگرام، می‌توانید روی فضای خالی دیاگرام راست‌کلیک کرده و “New Text Annotation” را انتخاب کنید. یک کادر متنی ظاهر می‌شود که می‌توانید توضیحات مورد نیاز خود را در آن تایپ کنید. این ویژگی برای مستندسازی بخش‌های خاصی از طراحی دیتابیس یا هایلایت کردن نکات مهم بسیار مفید است.

با استفاده از این ابزار قدرتمند در SSMS، می‌توانید یک نمایش بصری شفاف و دقیق از دیتابیس خود ایجاد کنید که نه تنها به شما در درک بهتر ساختار کمک می‌کند، بلکه فرآیند طراحی و نگهداری پایگاه داده را نیز ساده‌تر می‌سازد. در ادامه چند مثال از کوئری‌های SQL مرتبط با Database Diagrams و مدیریت آن را مشاهده می‌کنید که برای متخصصان SQL Server مفید خواهد بود:

**کوئری برای بررسی وجود اشیاء پشتیبانی دیاگرام:**

این کوئری بررسی می‌کند که آیا جداول سیستمی مورد نیاز برای ذخیره‌سازی دیاگرام‌ها در دیتابیس جاری شما وجود دارند یا خیر. این یک گام عیب‌یابی مفید است:


SELECT SCHEMA_NAME(schema_id) AS SchemaName, name AS TableName
FROM sys.tables
WHERE name IN ('dtproperties', 'sysdiagrams');

اگر این جداول وجود نداشته باشند، SSMS هنگام تلاش برای ایجاد اولین دیاگرام، آن‌ها را ایجاد خواهد کرد. خروجی این کوئری نام شمای مربوطه و نام جداول سیستم را نمایش می‌دهد.

**کوئری برای مشاهده لیست دیاگرام‌های موجود:**

با استفاده از این کوئری می‌توانید تمام دیاگرام‌های ذخیره‌شده در دیتابیس فعلی را به همراه اطلاعات مربوط به مالک و ID آن‌ها مشاهده کنید:


SELECT name AS DiagramName, principal_id AS OwnerID, diagram_id AS DiagramID, version
FROM sysdiagrams;

این کوئری اطلاعاتی مانند نام دیاگرام (DiagramName)، ID مالک آن (OwnerID)، ID منحصربه‌فرد دیاگرام (DiagramID) و نسخه آن را از جدول سیستمی sysdiagrams بازیابی می‌کند. این اطلاعات می‌تواند برای مدیریت دیاگرام‌ها و عیب‌یابی مفید باشد.

**کوئری برای حذف یک دیاگرام خاص (احتیاط کنید):**

اگر نیاز به حذف یک دیاگرام از دیتابیس خود دارید، می‌توانید از دستور DROP PROCEDURE استفاده کنید، زیرا دیاگرام‌ها به عنوان نوع خاصی از روال‌های ذخیره‌شده (stored procedures) در نظر گرفته می‌شوند:


EXEC sp_dropdiagram 'SalesSchema', @owner_id = NULL;

در این دستور، ‘SalesSchema’ نام دیاگرامی است که می‌خواهید حذف کنید و @owner_id = NULL به این معنی است که مالک آن کاربر جاری است یا به صورت پیش‌فرض تنظیم شده است. قبل از اجرای این دستور، اطمینان حاصل کنید که نام دیاگرام صحیح را وارد کرده‌اید، زیرا این عمل غیر قابل بازگشت است و دیاگرام را برای همیشه حذف می‌کند.

استفاده از دیاگرام‌های دیتابیس در SSMS یک روش عالی برای بهبود درک و مدیریت ساختارهای پیچیده پایگاه داده است. این ابزار به متخصصان سئو و توسعه‌دهندگان کمک می‌کند تا با دیدی جامع‌تر به طراحی و بهینه‌سازی دیتابیس بپردازند و در نتیجه، عملکرد و قابلیت نگهداری سیستم‌های اطلاعاتی را افزایش دهند.

 

من علی دستجردی‌ام؛ عاشق کار با دیتا، از SQL Server تا بیگ‌دیتا و هوش مصنوعی. دغدغه‌ام کشف ارزش داده‌ها و به‌اشتراک‌گذاری تجربه‌هاست. ✦ رزومه من: alidastjerdi.com ✦

عضویت
منو باخبر کن!!!
نام
ایمیل

0 دیدگاه
Inline Feedbacks
دیدن تمامی کامنتها

فوتر سایت

ورود به سایت

sqlyar

هنوز عضو نیستید؟

ورود به سایت

هنوز تبت نام نکردید ؟