ممنون میشم راهنمایی کنید مشکل از کجاست
معرفی JSON Web Token
آموزش LINQ بخش چهارم
انواع JOIN :
• Inner JOIN
• Group JOIN
• Left JOIN
کلاسهای زیر را در نظر بگیرید:
/// <summary> /// دستور العمل /// </summary> class Recipe { public int Id { get; set; } public string Name { get; set; } } /// <summary> /// بازخورد /// </summary> class Review { public int RecipeId { get; set; } public string ReviewText { get; set; } }
Inner Join
این دستور عنصری از توالی اول را که متناظر با آن عنصری در توالی دوم وجود داشته باشد، به خروجی میبرد.
مثال:
Recipe[] recipes = { new Recipe {Id = 1, Name = "Mashed Potato"}, new Recipe {Id = 2, Name = "Crispy Duck"}, new Recipe {Id = 3, Name = "Sachertorte"} }; Review[] reviews = { new Review {RecipeId = 1, ReviewText = "Tasty!"}, new Review {RecipeId = 1, ReviewText = "Not nice :("}, new Review {RecipeId = 1, ReviewText = "Pretty good"}, new Review {RecipeId = 2, ReviewText = "Too hard"}, new Review {RecipeId = 2, ReviewText = "Loved it"} }; var query = from recipe in recipes join review in reviews on recipe.Id equals review.RecipeId select new //anonymous type { RecipeName = recipe.Name, RecipeReview = review.ReviewText }; foreach (var item in query) { Console.WriteLine($"{item.RecipeName}-{item.RecipeReview}"); }
Mashed Potato-Tasty! Mashed Potato-Not nice :( Mashed Potato-Pretty good Crispy Duck-Too hard Crispy Duck-Loved it
Group Join
بکارگیری into به همراه join، دستور Group Join را میسازد.
var query = from recipe in recipes join review in reviews on recipe.Id equals review.RecipeId into reviewGroup select new //anonymous type { RecipeName = recipe.Name, Reviews = reviewGroup//collection of related reviews }; foreach (var item in query) { Console.WriteLine($"Review for {item.RecipeName}"); foreach (var review in item.Reviews) { Console.WriteLine($"-{review.ReviewText}"); } }
متغیر reviewGroup توالی حاصل از اجرای join را نمایش میدهد. برای ایجاد توالی خروجی، نتیجه به یک نوع بی نام، بازتاب شده است. هر عنصر در نوع بی نام یک گروه را نشان میدهد. نوع بی نام شامل دو خصوصیت RecipeName که مقدار آن از توالی اول میآید و Reviews که حاصل خروجی Join است میباشد.
خروجی مثال بالا به شکل زیر است:
Review for Mashed Potato -Tasty! -Not nice :( -Pretty good Review for Crispy Duck -Too hard -Loved it Review for Sachertorte
Left outer join
در این مثال از مجموعههای تعریف شدهی در بخش اول مطلب استفاده کردهایم:
var query = from recipe in recipes join review in reviews on recipe.Id equals review.RecipeId into reviewGroup from rg in reviewGroup.DefaultIfEmpty() select new //anonymous type { RecipeName = recipe.Name, //RecipeReview = rg.ReviewText SystemNullException RecipeReview = (rg == null ? "n/a" : rg.ReviewText) }; foreach (var item in query) { Console.WriteLine($"{item.RecipeName}-{item.RecipeReview}"); }
خروجی مثال فوق به شکل زیر است:
Mashed Potato-Tasty! Mashed Potato-Not nice :( Mashed Potato-Pretty good Crispy Duck-Too hard Crispy Duck-Loved it Sachertorte-n/a
مثال:
var query = from recipe in recipes join review in reviews on recipe.Id equals review.RecipeId into reviewGroup from rg in reviewGroup.DefaultIfEmpty(new Review { ReviewText = "N/A" }) select new //anonymous type { RecipeName = recipe.Name, RecipeReview = rg.ReviewText }; foreach (var item in query) { Console.WriteLine($"{item.RecipeName}-{item.RecipeReview}"); }
Mashed Potato-Tasty! Mashed Potato-Not nice :( Mashed Potato-Pretty good Crispy Duck-Too hard Crispy Duck-Loved it Sachertorte-N/A
C#.NET for non-engineers.
The first course of "A Sr. Developer Course" courses. which contains:
1- C# Fundamentals for non-engineers.
2- DataBase for non-engineers.
3- Asp.NET WebForm for Non-engineers.
4- Application Architecture for no-engineers.
5- ASP.NET MVC for non-engineers.
6- Angular for non-engineers.
This is a course for who knows noting about C# and development if you know nothing about Array, variable, loop, and conditions you are in the right place.
at the end of this course, we will create one small university registration console application together.
You will learn in this course:
C#.NET
.NET Framework
Methods
Recursive methods
C# Primitive Types/Complex Types
conditions
switch case
Arrays
if statement
switch
loops
Creating a method
ref, out
enums
OOP/Object-oriented programing
Generics
Error handling
problem-solving
working with files
level: beginners to upper intermediate
01-Introduction to Directives 02-Demo. Creating Your First Directive 03-Demo. Domain Specific Language via Custom Elements 04-Demo. Isolating Directive Scope 05-Demo. Exploring Isolate Scope Bindings 06-Demo. Handling Events with Directives 07-Demo. Observing and Responding to Changes 08-Demo. Using Controllers within Directives 09-Demo. Sharing Directive Controllers via Require 10-Demo. Directive Priority and using Terminal 11-Demo. Using Require with Nested Directives 12-Demo. Understanding Transclusion 13-Demo. Using Compile to Transform the DOM 14-Demo. Making jQuery More Explicit with Directives 15-Summary
چندی قبل مطلبی را در این سایت در مورد معرفی الگویی که توسط آن میتوان اعمال غیر همزمان را به صورت پی در پی انجام داد، مطالعه کردید:
و بحث اصلی مطالب فوق هم این است:
"در برنامه نویسی متداول همیشه عادت داریم که اعمال به صورت A –> B –> C انجام شوند. اما در Async programming ممکن است ابتدا C انجام شود، سپس A و بعد B یا هر حالت دیگری صرفنظر از تقدم و تاخر آنها در حین معرفی متدهای مرتبط در یک قطعه کد. همچنین میزان خوانایی این نوع کدنویسی نیز مطلوب نیست...."
خبر خوش آن است که پشتیبانی از این نوع مدل پی در پی برنامه نویسی در نگارشهای بعدی سی شارپ و VB.NET اضافه شده است.
لیستی از مقالات منتشر شده در این مورد را در ادامه ملاحظه خواهید کرد:
علاوه بر آن یک سری ویدیوی مرتبط با این بحث نیز منتشر شده است: