C# : LINQ

[".0s4*0|collections;datetime-format;linq",["F@eOQTU^","HCOIKLKIHAIOBGQGICMALRGAMA","OOOCBCCSTUUUUTTUUUUOCBYFGDGDGDHDGDGDHDGDFADADOCOCCPGDGDGDHDGDADFOCCOCBOCCPRDRDGDGDGDHDADADADGDADFOBBOCCCBOWBSTTUUUUTTUUUU",".tdwet.rr.rehrs..",".NET","Array","Dictionary","List","String","2D","Async","Console","DataTable","Dates","DateTime","Enum","File","For","Foreach","Format","IEnumerable","If","IndexOf","Lambda","LINQ","Optimization","Parse","Path","Process","Property","Random","Regex","Replace","Sort","Split","Static","Substring","Switch","Tuple","While","Join."," This is a keyword in LINQ. As with other query languages (such as SQL) joining matches every element in two collections based on some condition.","Queries."," We use this keyword in a query expression (beginning with from). We create new data structures (projections) based on the contents of elements.","First example."," This first example shows the Join extension method from the System.Linq namespace. And then it shows the equivalent join query expression syntax. ","Internally: ","The join query is translated to the Join() extension method by the C# compiler.","Extension ","extension","Tip: ","You can read in painful detail how query expressions are translated in the chapter on Expressions (7) in the C# specification.","But: ","This material is complex, tiresome and not all that useful for actual development.","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","With Join,"," we provide delegates (lambdas) as arguments. These are clauses in a query. Both examples join ints1 with ints2. They select elements in ints1 that exist in ints2 with an added 1. ","So: ","If ints1 contains an element of value 4, it is selected only if there is an element of value of 5 in ints2.","Int Array ","int-array","Based on:"," .NET 4.5\n\n","C# program that uses Join","\n\nusing System;\nusing System.Linq;\n\nclass Program\n{\n static void Main()\n {","\n // Array 1.\n ","var ints1 = new int[3];\n ints1[0] = 4;\n ints1[1] = 3;\n ints1[2] = 0;","\n\n // Array 2.\n ","var ints2 = new int[3];\n ints2[0] = 5;\n ints2[1] = 4;\n ints2[2] = 2;\n\n {","\n // Join with method call.\n ","var result = ints1.","Join","<int, int, int, int>(ints2,\n x => x + 1,\n y => y,\n (x, y) => x);","\n\n // Display results.\n ","foreach (var r in result)\n {\n Console.WriteLine(r);\n }\n }\n\n {","\n // Join with query expression.\n ","var result = from t in ints1\n ","join"," x in ints2 on (t + 1) equals x\n select t;","\n\n // Display results.\n ","foreach (var r in result)\n {\n Console.WriteLine(r);\n }\n }\n }\n}\n\n","Output","\n\n4 ","(First loop)","\n3\n4 ","(Second loop)","\n3","Program notes."," In my view, the second syntax form\u2014with the query expression\u2014is easier to read. This would make it more maintainable and less likely to create bugs. ","Tip: ","The Join and GroupJoin methods are hard to use directly. They are best used indirectly, through the query syntax.","Example 2."," This example program uses two classes for storing data. Customer has an ID and a Name for each instance. And Order has an ID and a Product string for each instance. ","Main: ","In the Main method, we use the abbreviated C# syntax for constructing the array instances. Each has 4 elements.","Finally: ","The query expression uses the join keyword to create new objects where the ID equals.","C# program that uses join and equals in query","\n\nusing System;\nusing System.Linq;\n\nclass Customer\n{\n public int ID { get; set; }\n public string Name { get; set; }\n}\n\nclass Order\n{\n public int ID { get; set; }\n public string Product { get; set; }\n}\n\nclass Program\n{\n static void Main()\n {","\n // Example customers.\n ","var customers = new Customer[]\n {\n new Customer{ID = 5, Name = \"Sam\"},\n new Customer{ID = 6, Name = \"Dave\"},\n new Customer{ID = 7, Name = \"Julia\"},\n new Customer{ID = 8, Name = \"Sue\"}\n };","\n\n // Example orders.\n ","var orders = new Order[]\n {\n new Order{ID = 5, Product = \"Book\"},\n new Order{ID = 6, Product = \"Game\"},\n new Order{ID = 7, Product = \"Computer\"},\n new Order{ID = 8, Product = \"Shirt\"}\n };","\n\n // Join on the ID properties.\n ","var query = from c in customers\n ","join"," o in orders on c.ID equals o.ID\n select new { c.Name, o.Product };","\n\n // Display joined groups.\n ","foreach (var group in query)\n {\n Console.WriteLine(","\"{0} bought {1}\"",", group.Name, group.Product);\n }\n }\n}\n\n","Output","\n\nSam bought Book\nDave bought Game\nJulia bought Computer\nSue bought Shirt","In the query expression,"," the customers array is used and each element from that array is identified as \"c\". The orders array is also used, and each element from that is identified as \"o\". ","And: ","The join takes the ID property from \"c\" and \"o\" and matches them. As the matches occur, new elements are created in the result.","SQL: ","This syntax is basically the same as in SQL. Occasionally it is easier to develop logic in this style of language.","GroupJoin."," Join is different from GroupJoin. With Join, we cannot create a new type to store multiple results together in a single element. ","And: ","We can only select a single value. But GroupJoin is invoked with the join query expression keyword.","GroupJoin ","groupjoin","Fluent syntax, join IDs."," This example joins two arrays of elements on the ID property of each element. It uses Animal and Medication instances. ","So: ","A cat with a specific ID may have 2 medications prescribed to it. The Join call resolves all of these.","And: ","We use the Join() method with lambda expression arguments. This is equivalent a query expression with the \"join\" clause.","C# program that uses Join, lambda expressions","\n\nusing System;\nusing System.Linq;\n\nclass ","Animal","\n{\n public int ID { get; set; }\n public string Breed { get; set; }\n}\n\nclass ","Medication","\n{\n public int ID { get; set; }\n public string Type { get; set; }\n}\n\nclass Program\n{\n static void Main()\n {","\n // Example animals in veterinarian office.\n ","var animals = new Animal[]\n {\n new Animal{ID = 0, Breed = \"cat\"},\n new Animal{ID = 10, Breed = \"dog\"}\n };","\n\n // Example medications (prescriptions).\n ","var medications = new Medication[]\n {\n new Medication{ID = 10, Type = \"antibiotic\"},\n new Medication{ID = 0, Type = \"sedative\"},\n new Medication{ID = 0, Type = \"antihistimine\"}\n };","\n\n // Use fluent join syntax on ID.\n ","var query = animals.","Join","(medications,\n a ","=>"," a.ID,\n m ","=>"," m.ID,\n (a, m) ","=>"," new { a.Breed, m.Type });","\n\n // Results.\n ","foreach (var group in query)\n {\n Console.WriteLine(","$\"{group.Breed} prescribed {group.Type}\"",");\n }\n }\n}\n\n","Output","\n\ncat prescribed sedative\ncat prescribed antihistimine\ndog prescribed antibiotic","String.Join."," The \"join\" keyword in LINQ is not related to the string.Join method, which combines an array or List of strings into one string. Thread.Join is also a different thing. ","string.Join ","string-join","Thread.Join ","thread-join","Specification."," Part of this article is based on the C# specification. In the specification, detailed examples are given for how query expressions are processed. ","And: ","This is near the end of the horrifying 143-page chapter on expressions. Thoroughness is helpful in language specifications.","Note: ","Thanks to Rob Martin for suggesting the Join() fluent syntax example. Two lambda expressions must be used.","MDSN: ","The documentation at MSDN is not always the easiest to understand. But it helps with some documentation needs.","Queryable.Join: MDSN ","https://msdn.microsoft.com/en-us/library/bb534644%28v=vs.105%29.aspx","A summary."," Using the LINQ extensions in the C# language, we can implement join expressions. This can make some matching routines more concise in a program.","It can help us"," convert SQL logic to C# code in some cases as well. The Join extension method can be directly used. But this complicates syntax due to its use of 3 delegate methods. ","Delegates ","delegate","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","3679700504","data-ad-format","link","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto"],"url()","url()","url()"]

["url()","url()","url()","url()","url()","url()","url()","url()","url()","url()"]