eitaa logo
پروژه ASP.Net Core MVC (وب و سی شارپ)
120 دنبال‌کننده
168 عکس
38 ویدیو
376 فایل
❁﷽❁ آموزش 📖 برنامه نویسی ASP.Net Core MVC (وب و سی شارپ) Admin: @alialirezapanahi برنامه نویسی برنامه نویسی سی شارپ eitaa.com/sisharpapp برنامه نویسی وب eitaa.com/aspdatnet ویراستی virasty.com/alialirezapanahi آپارات aparat.com/alialirezapanahi
مشاهده در ایتا
دانلود
سلام! پارشیال ویو (Partial View) در ASP.NETCore MVC یک ویو (View) قابل استفاده مجدد است که می‌تواند بخشی از یک ویوی بزرگ‌تر باشد. پارشیال ویوها به شما امکان می‌دهند که اجزای ویو را جداگانه نگهداری و مدیریت کنید و از آن‌ها در چندین ویو یا کنترلر استفاده کنید. این ویژگی به شما کمک می‌کند تا کد ویو را تمیزتر و قابل نگهداری‌تر کنید. نحوه ایجاد پارشیال ویو: ایجاد پارشیال ویو: پارشیال ویوها را در پوشه Views/Shared یا در پوشه خاص ویوها قرار دهید. نام فایل پارشیال ویو باید با _ شروع شود (مثلاً _MyPartialView.cshtml). مثال پارشیال ویو (_MyPartialView.cshtml): <div> <h2>@Model.Title</h2> <p>@Model.Description</p> </div> - استفاده از HTML Helper: برای استفاده از پارشیال ویو با HTML Helper، از متد Html.Partial یا Html.RenderPartial استفاده کنید. مثال استفاده از HTML Helper: @model YourNamespace.Models.MyModel <div> <h1>صفحه اصلی</h1> @Html.Partial("_MyPartialView", Model) </div> در این مثال، پارشیال ویو _MyPartialView با مدل MyModel رندر می‌شود. - استفاده از Tag Helper: برای استفاده از پارشیال ویو با Tag Helper، از تگ <partial> استفاده کنید. مثال استفاده از Tag Helper: @model YourNamespace.Models.MyModel <div> <h1>صفحه اصلی</h1> <partial name="_MyPartialView" model="Model" /> </div> مزایای استفاده از پارشیال ویو: قابلیت استفاده مجدد: اجزای ویو را می‌توان در چندین ویو و کنترلر استفاده کرد. نگهداری و خوانایی بهتر: کد ویو تمیزتر و قابل نگهداری‌تر است. تست راحت‌تر: می‌توان پارشیال ویوها را به صورت مستقل تست کرد. با استفاده از پارشیال ویوها، می‌توانید ساختار ویوهای خود را ساده‌تر و قابل نگهداری‌تر کنید و از تکرار کدهای مشابه جلوگیری کنید.
ViewComponent چیست؟ ViewComponent ها در ASP.NETCore MVC اجزای قابل استفاده مجدد هستند که شبیه به پارشیال ویوها عمل می‌کنند، اما دارای منطق پردازش مجزا هستند. آن‌ها به شما امکان می‌دهند که بلوک‌های پیچیده UI را با منطق و رندرینگ مجزا ایجاد کنید. ویژگی‌ها و مزایا: قابلیت استفاده مجدد: می‌توانید ViewComponent ها را در چندین ویو و کنترلر استفاده کنید. جدا کردن منطق از نمایه: ViewComponent ها دارای منطق پردازش مستقل از ویوها هستند. بهبود تست‌پذیری: ViewComponent ها به راحتی تست‌پذیر هستند زیرا منطق آن‌ها جدا از ویوها است. نحوه ایجاد و استفاده از ViewComponent: ایجاد ViewComponent: یک کلاس ViewComponent ایجاد کنید و از ViewComponent ارث ببرید. متد Invoke یا InvokeAsync را پیاده‌سازی کنید. مثال: کلاسی به نام MyViewComponent ایجاد کنید: public class MyViewComponent : ViewComponent { public IViewComponentResult Invoke(string message) { return View("Default", message); } } ایجاد ویوی ViewComponent: یک ویو با نام Default.cshtml در پوشه Views/Shared/Components/MyViewComponent ایجاد کنید. مثال ویو (Default.cshtml): <div> <h2>پیام شما:</h2> <p>@Model</p> </div> استفاده از ViewComponent در ویو: با استفاده از Tag Helper می‌توانید ViewComponent را در ویو فراخوانی کنید. استفاده از Tag Helper: <vc:my message="سلام به ViewComponent!" /> با استفاده از ViewComponent ها می‌توانید اجزای پیچیده UI را ایجاد کرده و منطق و رندرینگ آن‌ها را به صورت مجزا مدیریت کنید. این کار به شما کمک می‌کند تا کدهای خود را تمیزتر و قابل نگهداری‌تر کنید و قابلیت استفاده مجدد اجزا را افزایش دهید.
خیلی خوب! بیایید یک مثال کامل از ViewComponent ایجاد کنیم که نام و ایمیل کاربر را به صورت پاپ‌آپ نمایش دهد و از Tag Helper استفاده کنیم. مرحله 1: ایجاد مدل کاربر ابتدا یک مدل ساده برای کاربر ایجاد کنید. public class User { public string Name { get; set; } public string Email { get; set; } } مرحله 2: ایجاد ViewComponent یک کلاس برای ViewComponent ایجاد کنید که منطق نمایش کاربر را در خود دارد. public class UserPopupViewComponent : ViewComponent { public IViewComponentResult Invoke(User user) { return View(user); } } مرحله 3: ایجاد ویوی ViewComponent یک ویو برای ViewComponent ایجاد کنید. این ویو در پوشه Views/Shared/Components/UserPopup قرار می‌گیرد و نام آن Default.cshtml است. @model YourNamespace.Models.User <div id="user-popup" style="display:none; position:fixed; top:50%; left:50%; transform:translate(-50%, -50%); background-color:white; border:1px solid black; padding:10px; z-index:1000;"> <h2>کاربر</h2> <p>نام: @Model.Name</p> <p>ایمیل: @Model.Email</p> <button onclick="closePopup()">بستن</button> </div> <script> function showPopup() { document.getElementById("user-popup").style.display = "block"; } function closePopup() { document.getElementById("user-popup").style.display = "none"; } </script> مرحله 4: استفاده از ViewComponent در ویو حال، می‌توانید از ViewComponent در ویوی اصلی خود استفاده کنید. به عنوان مثال، در ویوی Index.cshtml: @model YourNamespace.Models.User <h1>نمایش کاربر</h1> <button onclick="showPopup()">نمایش پاپ‌آپ کاربر</button> <vc:user-popup user="Model" /> نتیجه با این تنظیمات، وقتی کاربر روی دکمه "نمایش پاپ‌آپ کاربر" کلیک کند، پاپ‌آپی ظاهر می‌شود که نام و ایمیل کاربر را نمایش می‌دهد. شما می‌توانید با استفاده از Tag Helper <vc:user-popup> به راحتی ViewComponent را در هر ویویی فراخوانی کنید.
برای اضافه کردن مشخصات کاربر به پروژه ViewComponent که قبلاً توضیح داده شد، باید از طریق چند مرحله ساده اقدام کنیم. این مراحل شامل ایجاد و مقداردهی مدل کاربر و استفاده از آن در کنترلر و ویو است. مرحله 1: ایجاد مدل کاربر مدل User را با ویژگی‌های مورد نیاز مانند نام و ایمیل تعریف می‌کنیم: public class User { public string Name { get; set; } public string Email { get; set; } } مرحله 2: ایجاد ViewComponent کلاس ViewComponent برای نمایش اطلاعات کاربر ایجاد می‌شود: public class UserPopupViewComponent : ViewComponent { public IViewComponentResult Invoke(User user) { return View(user); } } مرحله 3: ایجاد ویوی ViewComponent ویو Default.cshtml را در پوشه Views/Shared/Components/UserPopup ایجاد می‌کنیم: @model YourNamespace.Models.User <div id="user-popup" style="display:none; position:fixed; top:50%; left:50%; transform:translate(-50%, -50%); background-color:white; border:1px solid black; padding:10px; z-index:1000;"> <h2>کاربر</h2> <p>نام: @Model.Name</p> <p>ایمیل: @Model.Email</p> <button onclick="closePopup()">بستن</button> </div> <script> function showPopup() { document.getElementById("user-popup").style.display = "block"; } function closePopup() { document.getElementById("user-popup").style.display = "none"; } </script> مرحله 4: استفاده از ViewComponent در ویو اصلی در ویوی اصلی (مثلاً Index.cshtml) از ViewComponent استفاده می‌کنیم: @model YourNamespace.Models.User <h1>نمایش کاربر</h1> <button onclick="showPopup()">نمایش پاپ‌آپ کاربر</button> <vc:user-popup user="Model" /> مرحله 5: مقداردهی مدل کاربر در کنترلر در کنترلر خود، مقداردهی مدل کاربر و ارسال آن به ویو انجام می‌شود: public class HomeController : Controller { public IActionResult Index() { var user = new User { Name = "علی", Email = "ali@example.com" }; return View(user); } } نتیجه با این تنظیمات، وقتی کاربر روی دکمه "نمایش پاپ‌آپ کاربر" کلیک کند، پاپ‌آپی ظاهر می‌شود که نام و ایمیل کاربر را نمایش می‌دهد. شما می‌توانید با استفاده از Tag Helper <vc:user-popup> به راحتی ViewComponent را در هر ویویی فراخوانی کنید.
برای نمایش یک پاپ‌آپ ساده که نام و ایمیل کاربر را نمایش می‌دهد، می‌توانید از JavaScript استفاده کنید. در اینجا یک مثال کامل از اسکریپت پاپ‌آپ و نحوه استفاده از آن در یک ویو در ASP.NETCore آورده شده است. مرحله 1: ایجاد اسکریپت پاپ‌آپ اسکریپت پاپ‌آپ باید شامل کدی باشد که پاپ‌آپ را نمایش و پنهان می‌کند. این اسکریپت را می‌توانید در همان ویو یا در یک فایل جداگانه قرار دهید. اسکریپت پاپ‌آپ: <script> function showPopup() { document.getElementById("user-popup").style.display = "block"; } function closePopup() { document.getElementById("user-popup").style.display = "none"; } </script> مرحله 2: ایجاد HTML پاپ‌آپ پاپ‌آپ را به صورت یک <div> با استایل‌های CSS مناسب تعریف کنید تا در مرکز صفحه نمایش داده شود. HTML پاپ‌آپ: <div id="user-popup" style="display:none; position:fixed; top:50%; left:50%; transform:translate(-50%, -50%); background-color:white; border:1px solid black; padding:10px; z-index:1000;"> <h2>کاربر</h2> <p>نام: @Model.Name</p> <p>ایمیل: @Model.Email</p> <button onclick="closePopup()">بستن</button> </div> مرحله 3: استفاده از اسکریپت و HTML در ویو در ویوی اصلی خود، اسکریپت و HTML پاپ‌آپ را قرار دهید و یک دکمه برای نمایش پاپ‌آپ ایجاد کنید. مثال ویو (Index.cshtml): @model YourNamespace.Models.User <!DOCTYPE html> <html> <head> <title>نمایش کاربر</title> <style> -popup { display: none; position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background-color: white; border: 1px solid black; padding: 10px; z-index: 1000; } </style> </head> <body> <h1>نمایش کاربر</h1> <button onclick="showPopup()">نمایش پاپ‌آپ کاربر</button> <div id="user-popup"> <h2>کاربر</h2> <p>نام: @Model.Name</p> <p>ایمیل: @Model.Email</p> <button onclick="closePopup()">بستن</button> </div> <script> function showPopup() { document.getElementById("user-popup").style.display = "block"; } function closePopup() { document.getElementById("user-popup").style.display = "none"; } </script> </body> </html> نتیجه با این تنظیمات، وقتی کاربر روی دکمه "نمایش پاپ‌آپ کاربر" کلیک کند، پاپ‌آپی ظاهر می‌شود که نام و ایمیل کاربر را نمایش می‌دهد. با کلیک روی دکمه "بستن" پاپ‌آپ بسته می‌شود. این اسکریپت به شما امکان می‌دهد که اطلاعات کاربر را به صورت پاپ‌آپ نمایش دهید و کنترل بهتری بر روی ظاهر و عملکرد پاپ‌آپ داشته باشید.
Area چیست در ASP.NETCore MVC، Area یا مناطق به شما این امکان را می‌دهند که برنامه خود را به بخش‌های کوچکتر و ماژولارتر تقسیم کنید. این ویژگی برای مدیریت و سازماندهی برنامه‌های بزرگ و پیچیده بسیار مفید است، زیرا شما می‌توانید بخش‌های مختلف برنامه خود را به صورت جداگانه توسعه و نگهداری کنید. ویژگی‌ها و مزایا: - سازماندهی بهتر: Areas به شما امکان می‌دهند که کنترلرها، ویوها و مدل‌ها را به صورت منطقی و ساختاریافته سازماندهی کنید. - قابلیت توسعه مجزا: هر Area می‌تواند به صورت مستقل توسعه یابد که این کار تیمی را تسهیل می‌کند. - کاهش پیچیدگی: با تقسیم برنامه به Areas مختلف، پیچیدگی کلی برنامه کاهش می‌یابد و نگهداری آن ساده‌تر می‌شود. نحوه ایجاد و استفاده از Areas: ایجاد Area: ابتدا یک پوشه به نام Areas در ریشه پروژه خود ایجاد کنید. در داخل پوشه Areas، یک پوشه برای هر Area که می‌خواهید ایجاد کنید. به عنوان مثال، Admin. ساختار پوشه: /Areas /Admin /Controllers /Views /Models ایجاد کنترلر در Area: کنترلرهای Area در پوشه Controllers قرار می‌گیرند. از Area attribute برای تعیین Area کنترلر استفاده کنید. مثال کنترلر: [Area("Admin")] public class HomeController : Controller { public IActionResult Index() { return View(); } } ایجاد ویو در Area: ویوهای مربوط به Area در پوشه Views قرار می‌گیرند و ساختار پوشه باید نام کنترلر را نیز شامل شود. ساختار پوشه ویو: /Areas /Admin /Views /Home Index.cshtml تنظیم مسیرها برای Area: در فایل Startup.cs یا Program.cs، مسیرهای Area را تنظیم کنید تا بتوانید به درستی به آن‌ها دسترسی داشته باشید. مثال تنظیم مسیرها در Program.cs: var builder = WebApplication.CreateBuilder(args); builder.Services.AddControllersWithViews(); var app = builder.Build(); app.UseRouting(); app.UseEndpoints(endpoints => { endpoints.MapControllerRoute( name: "areas", pattern: "{area:exists}/{controller=Home}/{action=Index}/{id?}"); }); app.Run(); دسترسی به کنترلرها و ویوهای Area: برای دسترسی به کنترلرها و ویوهای موجود در یک Area، باید نام Area را در URL مشخص کنید. مثال URL: https://example.com/Admin/Home/Index نتیجه: با استفاده از Areas، می‌توانید برنامه‌های بزرگ خود را به بخش‌های کوچکتر و ماژولارتر تقسیم کنید، که این کار توسعه و نگهداری برنامه را ساده‌تر و مؤثرتر می‌کند.
Introduction به بانک‌های اطلاعاتی (Databases) بانک اطلاعاتی یا دیتابیس (Database) یک مجموعه سازمان‌یافته از داده‌ها است که برای ذخیره، مدیریت و بازیابی اطلاعات به‌صورت کارآمد و ساختاریافته طراحی شده است. بانک‌های اطلاعاتی به شما امکان می‌دهند تا داده‌ها را به‌صورت منطقی دسته‌بندی و نگهداری کنید و از ابزارها و زبان‌های مختلف برای تعامل با این داده‌ها استفاده کنید. انواع بانک‌های اطلاعاتی بانک‌های اطلاعاتی به دسته‌های مختلفی تقسیم می‌شوند که هر کدام کاربردهای خاص خود را دارند: 1- بانک‌های اطلاعاتی رابطه‌ای (Relational Databases): - این نوع بانک‌های اطلاعاتی داده‌ها را در جداول با رابطه‌های تعریف شده ذخیره می‌کنند. - از زبان SQL برای تعامل با داده‌ها استفاده می‌کنند. - مثال: MySQL, PostgreSQL, SQL Server, Oracle. 2- بانک‌های اطلاعاتی NoSQL: - برای ذخیره‌سازی داده‌های غیرساختاریافته و نیمه‌ساختاریافته استفاده می‌شوند. - از انواع مختلف ساختارهای داده‌ای مانند مستندات، گراف‌ها، کلید-مقدار و ستون‌های گسترده استفاده می‌کنند. - مثال: MongoDB, Cassandra, Redis, CouchDB. 3- بانک‌های اطلاعاتی شی‌گرا (Object-Oriented Databases): - داده‌ها را به‌صورت اشیاء ذخیره می‌کنند که شامل داده‌ها و متدهای مرتبط با آن‌ها هستند. - مثال: db4o, ObjectDB. 4- بانک‌های اطلاعاتی گراف (Graph Databases): - داده‌ها را به‌صورت گره‌ها (Nodes) و لبه‌ها (Edges) ذخیره می‌کنند. - برای مدل‌سازی روابط پیچیده و چندگانه استفاده می‌شوند. - مثال: Neo4j, ArangoDB. اجزای اصلی بانک اطلاعاتی - جدول‌ها (Tables): واحدهای اصلی ذخیره‌سازی در بانک اطلاعاتی رابطه‌ای که داده‌ها را در ردیف‌ها و ستون‌ها ذخیره می‌کنند. - رکوردها (Records): هر ردیف در یک جدول به عنوان یک رکورد شناخته می‌شود و حاوی داده‌های مرتبط به یک ورودی خاص است. - فیلدها (Fields): هر ستون در یک جدول به عنوان یک فیلد شناخته می‌شود و نوع داده‌های خاصی را نگهداری می‌کند. - کلیدها (Keys): از کلیدها برای شناسایی منحصربه‌فرد رکوردها و ایجاد روابط بین جداول استفاده می‌شود. دو نوع مهم کلید شامل کلید اصلی (Primary Key) و کلید خارجی (Foreign Key) هستند. مزایای استفاده از بانک اطلاعاتی - کارایی بالا: بانک‌های اطلاعاتی برای جستجو، بازیابی و مدیریت داده‌ها بهینه‌سازی شده‌اند. - قابلیت اطمینان: داده‌ها در بانک اطلاعاتی به صورت پایدار و امن ذخیره می‌شوند. - مدیریت همزمانی: امکان مدیریت چندین کاربر به صورت همزمان بدون تداخل در داده‌ها. - مقیاس‌پذیری: امکان افزایش ظرفیت ذخیره‌سازی و پردازش با افزایش حجم داده‌ها. ابزارهای مدیریت بانک اطلاعاتی - سیستم‌های مدیریت بانک اطلاعاتی (DBMS): نرم‌افزارهایی که برای مدیریت داده‌ها و تعامل با بانک اطلاعاتی استفاده می‌شوند. مثال: MySQL, PostgreSQL, MongoDB, Oracle DB. - ابزارهای طراحی و مدل‌سازی بانک اطلاعاتی: نرم‌افزارهایی که برای طراحی ساختار بانک اطلاعاتی و مدل‌سازی داده‌ها استفاده می‌شوند. مثال: MySQL Workbench, ER/Studio, pgAdmin. بانک‌های اطلاعاتی بخشی حیاتی از هر سیستم اطلاعاتی هستند و نقش مهمی در ذخیره‌سازی و مدیریت داده‌ها دارند.
طراحی بانک اطلاعاتی فرآیند ایجاد یک ساختار منطقی و فیزیکی برای ذخیره، مدیریت و بازیابی داده‌ها در یک سیستم مدیریت بانک اطلاعاتی (DBMS) است. این فرآیند شامل تعریف جداول، روابط بین آن‌ها و قوانین یکپارچگی داده‌ها است. هدف اصلی طراحی بانک اطلاعاتی ایجاد یک سیستم کارا، امن و مقیاس‌پذیر برای مدیریت داده‌ها است. طراحی بانک اطلاعاتی: 1- تجزیه و تحلیل نیازمندی‌ها: درک نیازهای کسب و کار و فرآیندهای مختلفی که داده‌ها در آن‌ها نقش دارند. شناسایی موجودیت‌های کلیدی و روابط بین آن‌ها. 2- مدل‌سازی موجودیت-رابطه (ER): ایجاد نمودارهای ER برای نمایش موجودیت‌ها (Entities) و روابط (Relationships) بین آن‌ها. تعیین ویژگی‌های هر موجودیت و تعریف روابط یک به یک (1:1)، یک به چند (1:N)، و چند به چند (N:M). 3- طراحی منطقی: تبدیل مدل ER به یک مدل منطقی که شامل جداول، ستون‌ها و روابط کلیدی بین جداول است. تعریف کلیدهای اصلی (Primary Keys) و کلیدهای خارجی (Foreign Keys) برای ایجاد یکپارچگی داده‌ها. 4- طراحی فیزیکی: تعیین نحوه ذخیره‌سازی داده‌ها در سیستم مدیریت بانک اطلاعاتی (DBMS) انتخاب شده. بهینه‌سازی ذخیره‌سازی و بازیابی داده‌ها با استفاده از ایندکس‌ها، پارتیشن‌بندی و سایر تکنیک‌های بهینه‌سازی. توضیح موجودیت‌ها: - محصول (Product): موجودیتی که نماینده یک کالا یا خدمات است. ویژگی‌هایی مانند نام محصول، قیمت، توصیف، موجودی، و شناسه یکتا (ID) دارد. - مشتری (Customer): موجودیتی که نماینده فرد یا سازمانی است که محصولات یا خدمات را خریداری می‌کند. ویژگی‌هایی مانند نام مشتری، آدرس، ایمیل، شماره تماس، و شناسه یکتا (ID) دارد. - سفارش (Order): موجودیتی که نماینده یک تراکنش خرید انجام شده توسط مشتری است. ویژگی‌هایی مانند تاریخ سفارش، شناسه مشتری، شناسه محصول، مقدار، و وضعیت سفارش دارد. روابط بین موجودیت‌ها: - ارتباط یک به یک (1:1): در این نوع ارتباط، هر رکورد از یک موجودیت با حداکثر یک رکورد در موجودیت دیگر مرتبط است. مثال: اگر یک مشتری تنها یک حساب کاربری داشته باشد، ارتباط بین مشتری و حساب کاربری یک به یک است. - ارتباط یک به چند (1:N): در این نوع ارتباط، هر رکورد از یک موجودیت با چندین رکورد در موجودیت دیگر مرتبط است. مثال: یک مشتری می‌تواند چندین سفارش ثبت کند، اما هر سفارش تنها متعلق به یک مشتری است. این یک ارتباط یک به چند بین مشتری و سفارش است. - ارتباط چند به چند (N:M): در این نوع ارتباط، هر رکورد از یک موجودیت می‌تواند با چندین رکورد در موجودیت دیگر مرتبط باشد و بالعکس. مثال: محصولات و سفارش‌ها می‌توانند یک ارتباط چند به چند داشته باشند، زیرا یک سفارش می‌تواند شامل چندین محصول باشد و یک محصول می‌تواند در چندین سفارش باشد. برای مدل‌سازی این ارتباط، معمولاً از یک جدول میانی (Join Table) استفاده می‌شود. طراحی دقیق روابط: - کلیدهای اصلی و خارجی: استفاده از کلیدهای اصلی برای شناسایی یکتای رکوردها در هر جدول. استفاده از کلیدهای خارجی برای ایجاد روابط بین جداول و حفظ یکپارچگی داده‌ها. - قواعد یکپارچگی داده‌ها: تعریف و اعمال قواعد برای اطمینان از صحت و انسجام داده‌ها در بانک اطلاعاتی. با رعایت این اصول و مراحل، می‌توانید یک بانک اطلاعاتی کارا و سازماندهی شده طراحی کنید که نیازهای کسب و کار شما را برآورده کند.
در طراحی بانک اطلاعاتی SQL Server، جداول محصول، مشتری و سفارش با توجه به روابط یک به یک، یک به چند و چند به چند تعریف می‌شوند. این جداول به همراه کلیدهای اصلی و خارجی به شما امکان می‌دهند تا داده‌ها را به صورت منظم و ساختاریافته ذخیره کنید و روابط بین آن‌ها را مدیریت کنید. 1. طراحی جداول و روابط جداول: محصول (Product) مشتری (Customer) سفارش (Order) روابط: یک به یک (1:1) یک به چند (1:N) چند به چند (N:M) 2. طراحی جداول SQL Server جدول محصول (Product): CREATE TABLE Product ( ProductID INT PRIMARY KEY, ProductName NVARCHAR(100), Price DECIMAL(10, 2) ); جدول مشتری (Customer): CREATE TABLE Customer ( CustomerID INT PRIMARY KEY, CustomerName NVARCHAR(100), Email NVARCHAR(100) ); جدول سفارش (Order): CREATE TABLE [Order] ( OrderID INT PRIMARY KEY, OrderDate DATETIME, CustomerID INT, FOREIGN KEY (CustomerID) REFERENCES Customer(CustomerID) ); 3. پیاده‌سازی روابط ارتباط یک به یک (1:1) برای ایجاد یک رابطه یک به یک بین دو جدول، هر دو جدول باید دارای یک کلید اصلی مشترک باشند. به عنوان مثال، فرض کنید هر مشتری فقط یک آدرس دارد: جدول آدرس (Address): CREATE TABLE Address ( CustomerID INT PRIMARY KEY, Street NVARCHAR(100), City NVARCHAR(100), PostalCode NVARCHAR(20), FOREIGN KEY (CustomerID) REFERENCES Customer(CustomerID) ); ارتباط یک به چند (1:N) در این نوع ارتباط، یک رکورد در جدول والد می‌تواند با چندین رکورد در جدول فرزند مرتبط باشد. به عنوان مثال، یک مشتری می‌تواند چندین سفارش داشته باشد: جدول سفارش (Order): CREATE TABLE [Order] ( OrderID INT PRIMARY KEY, OrderDate DATETIME, CustomerID INT, FOREIGN KEY (CustomerID) REFERENCES Customer(CustomerID) ); 4. پیاده‌سازی ارتباط چند به چند (N:M) برای ایجاد یک رابطه چند به چند، به یک جدول واسط نیاز است تا رابطه بین دو جدول را مدیریت کند. به عنوان مثال، یک سفارش می‌تواند چندین محصول داشته باشد و یک محصول می‌تواند در چندین سفارش باشد: جدول واسط سفارش-محصول (OrderProduct): CREATE TABLE OrderProduct ( OrderID INT, ProductID INT, Quantity INT, PRIMARY KEY (OrderID, ProductID), FOREIGN KEY (OrderID) REFERENCES [Order](OrderID), FOREIGN KEY (ProductID) REFERENCES Product(ProductID) ); نتیجه‌گیری با استفاده از این طراحی، شما می‌توانید روابط مختلف بین جداول محصول، مشتری و سفارش را به صورت دقیق و ساختاریافته مدیریت کنید. هر نوع ارتباط (یک به یک، یک به چند و چند به چند) با استفاده از کلیدهای اصلی و خارجی و جدول‌های واسط به درستی پیاده‌سازی شده است. این طراحی به شما امکان می‌دهد تا داده‌ها را به صورت منظم ذخیره و بازیابی کنید و از یکپارچگی و انسجام داده‌ها اطمینان حاصل کنید.
در SQL Server، ارتباط بین جداول با استفاده از کلیدهای اصلی (Primary Keys) و کلیدهای خارجی (Foreign Keys) تعریف می‌شود. این کلیدها به حفظ یکپارچگی داده‌ها و ایجاد روابط بین جداول کمک می‌کنند. روش‌های مختلفی برای تعریف و مدیریت این ارتباطات وجود دارد. بیایید این روش‌ها را بررسی کنیم. کلیدهای اصلی (Primary Key): کلید اصلی یک یا چند ستون است که به طور منحصر به فرد هر رکورد در یک جدول را شناسایی می‌کند. هر جدول می‌تواند تنها یک کلید اصلی داشته باشد، و این کلید نمی‌تواند مقادیر تکراری یا null داشته باشد. تعریف کلید اصلی: CREATE TABLE Customer ( CustomerID INT PRIMARY KEY, CustomerName NVARCHAR(100), Email NVARCHAR(100) ); کلیدهای خارجی (Foreign Key): کلید خارجی ستونی است که به یک کلید اصلی در جدول دیگر ارجاع می‌دهد و برای تعریف روابط بین جداول استفاده می‌شود. کلید خارجی به حفظ یکپارچگی داده‌ها بین جداول مختلف کمک می‌کند. تعریف کلید خارجی: CREATE TABLE [Order] ( OrderID INT PRIMARY KEY, OrderDate DATETIME, CustomerID INT, FOREIGN KEY (CustomerID) REFERENCES Customer(CustomerID) ); روش‌های ارتباط بین جداول: ارتباط یک به یک (1:1): در این نوع ارتباط، هر رکورد در جدول اول با حداکثر یک رکورد در جدول دوم مرتبط است. معمولاً این نوع ارتباط با استفاده از کلید اصلی در هر دو جدول و استفاده از کلید خارجی در یکی از جداول پیاده‌سازی می‌شود. مثال: CREATE TABLE Customer ( CustomerID INT PRIMARY KEY, CustomerName NVARCHAR(100), Email NVARCHAR(100) ); CREATE TABLE Address ( AddressID INT PRIMARY KEY, CustomerID INT UNIQUE, Street NVARCHAR(100), City NVARCHAR(100), PostalCode NVARCHAR(20), FOREIGN KEY (CustomerID) REFERENCES Customer(CustomerID) ); ارتباط یک به چند (1:N): در این نوع ارتباط، هر رکورد در جدول والد با چندین رکورد در جدول فرزند مرتبط است. این نوع ارتباط با استفاده از کلید اصلی در جدول والد و کلید خارجی در جدول فرزند پیاده‌سازی می‌شود. مثال: CREATE TABLE Customer ( CustomerID INT PRIMARY KEY, CustomerName NVARCHAR(100), Email NVARCHAR(100) ); CREATE TABLE [Order] ( OrderID INT PRIMARY KEY, OrderDate DATETIME, CustomerID INT, FOREIGN KEY (CustomerID) REFERENCES Customer(CustomerID) ); ارتباط چند به چند (N:M): در این نوع ارتباط، هر رکورد در جدول اول می‌تواند با چندین رکورد در جدول دوم مرتبط باشد و بالعکس. برای پیاده‌سازی این نوع ارتباط، از یک جدول میانی (Join Table) استفاده می‌شود که کلیدهای خارجی هر دو جدول اصلی را نگهداری می‌کند. مثال: CREATE TABLE Product ( ProductID INT PRIMARY KEY, ProductName NVARCHAR(100), Price DECIMAL(10, 2) ); CREATE TABLE [Order] ( OrderID INT PRIMARY KEY, OrderDate DATETIME, CustomerID INT, FOREIGN KEY (CustomerID) REFERENCES Customer(CustomerID) ); CREATE TABLE OrderProduct ( OrderID INT, ProductID INT, Quantity INT, PRIMARY KEY (OrderID, ProductID), FOREIGN KEY (OrderID) REFERENCES [Order](OrderID), FOREIGN KEY (ProductID) REFERENCES Product(ProductID) ); نتیجه‌گیری با استفاده از این روش‌ها، می‌توانید ارتباطات پیچیده بین جداول مختلف را مدیریت کنید و از یکپارچگی و انسجام داده‌ها در بانک اطلاعاتی خود اطمینان حاصل کنید. این ارتباطات به شما امکان می‌دهند تا داده‌های مرتبط را به صورت کارآمد جستجو و بازیابی کنید و ساختار بانک اطلاعاتی خود را منطقی و سازمان‌یافته نگه دارید.