اسکریپت: لیست جداول مورد ارجاع توسط Foreign Key در یک جدول

اسکریپت: لیست جداول مورد ارجاع توسط Foreign Key در یک جدول

نوشته شده توسط: زهرا فرهنگی
۰۶ آبان ۱۳۹۷
زمان مطالعه: 5 دقیقه
۰
(۰)

مقدمه

توسط دستور زیر می‌توان لیست تمامی جداولی که از طریق Foreign Keyهای یک جدول خاص به آنها ارجاع داده شده است را بدست آورد.

select distinct
schema_name(fk_tab.schema_id) + '.' + fk_tab.name as foreign_table,
'>-' as rel,
schema_name(pk_tab.schema_id) + '.' + pk_tab.name as primary_table
from sys.foreign_keys fk
inner join sys.tables fk_tab
on fk_tab.object_id = fk.parent_object_id
inner join sys.tables pk_tab
on pk_tab.object_id = fk.referenced_object_id
where fk_tab.[name] = 'Your table' -- enter table name here
-- and schema_name(fk_tab.schema_id) = 'Your table schema name'
order by schema_name(fk_tab.schema_id) + '.' + fk_tab.name,
schema_name(pk_tab.schema_id) + '.' + pk_tab.name

توجه: نام جدول مورد نظر خود را درون کد جای‌گزاری کرده و در صورتی که چندین جدول همنام در Schemaهای مختلف وجود دارد می‌توانید با خارج کردن کد مربوطه از حالت کامنت, اطلاعات جدول مورد نظر را آسان تر بدست آورید.

  •  Foreign_Table: نام جدول خارجی به همراه Schema; جدولی که به عنوان پارامتر داده شده است
  •  Rel: نماد ارتباط, مشخص کننده Foreign Key و جهت ارتباط
  •  Primary_Table: نام جدول اصلی (مورد ارجاع) به همراه Schema

یک نمونه از اجرای دستور بالا روی جدول Sales.SalesOrderHeader از دیتابیس Adventure Works

برای بدست آوردن اطلاعات بیش‌تر در مورد اسکریپت های پرکاربرد SQL ، به مقاله زیر مراجعه کنید.

چه رتبه ای می‌دهید؟

میانگین ۰ / ۵. از مجموع ۰

اولین نفر باش

title sign
دانلود مقاله
اسکریپت: لیست جداول مورد ارجاع توسط Foreign Key در یک جدول
فرمت PDF
صفحه
حجم 1 مگابایت
دانلود اسکریپت
title sign
معرفی نویسنده
زهرا فرهنگی
مقالات
51 مقاله توسط این نویسنده
محصولات
0 دوره توسط این نویسنده
زهرا فرهنگی

کارشناس پایگاه داده، در حال کسب تجربه در زمینه‌های تحلیل انباره داده، BI، بهینه سازی پایگاه‌های داده

پروفایل نویسنده
title sign
دیدگاه کاربران

ثبت نام رایگان در همایش Tehran .NET Conf 2023 ، همین الان کلیک کنید
ثبت نام رایگان..
close-image