40. LINQ ๊ธฐ๋ณธ ๋ฌธ๋ฒ•

2022. 4. 8. 09:16ยท๐Ÿ’ป Programming Language/C#
using System.Collections;

/*
[LINQ]

LINQ์˜ ์งˆ์˜ํ‘œํ˜„์‹ = ์ฟผ๋ฆฌ ์‹ (Query Expression) ์€ from ์ ˆ๋กœ ์‹œ์ž‘ํ•œ๋‹ค.
    - from ์ ˆ ๋‹ค์Œ์—๋Š” ๋ฐ์ดํ„ฐ ์›๋ณธ์ด ์˜จ๋‹ค. ๋ฐ์ดํ„ฐ ์›๋ณธ์€ ๋ฐฐ์—ด, ์ปฌ๋ ‰์…˜ ๋“ฑ์ด ์˜ฌ ์ˆ˜ ์žˆ๋‹ค.
    - from <๋ฒ”์œ„๋ณ€์ˆ˜> in <๋ฐ์ดํ„ฐ ์›๋ณธ> 
    ```csharp
    int[] aaa = {11,22,33,44,55}

    var res = from a in aaa
              where a % 2 != 0
              orderby a 
              select a;
    ```

    - where ์ ˆ์€ ๋ฒ”์œ„ ๋ณ€์ˆ˜์˜ ์กฐ๊ฑด์„ ์ง€์ •ํ•˜์—ฌ ๊ทธ ์กฐ๊ฑด์— ํ•ด๋‹นํ•˜๋Š” ๋ฐ์ดํ„ฐ๋ฅผ ๊ฑธ๋Ÿฌ๋‚ด๋Š” ์—ญํ• ์„ ํ•œ๋‹ค.
    - orderby์ ˆ์€ where ์ ˆ์—์„œ ๊ฑธ๋Ÿฌ๋‚ธ ๋ฐ์ดํ„ฐ๋ฅผ ์ •๋ ฌํ•˜๋Š” ์—ญํ• ์„ ํ•œ๋‹ค.
        - ๊ธฐ๋ณธ ์ •๋ ฌ๊ฐ’์€ ์˜ค๋ฆ„์ฐจ์ˆœ ascending ์œผ๋กœ ์ง€์ •๋˜์–ด ์žˆ๋‹ค. ๋‚ด๋ฆผ์ฐจ์ˆœ์€ descending
    - select ์ ˆ์€ ์งˆ์˜(Query)์˜ ์ตœ์ข… ๊ฒฐ๊ณผ๋ฅผ ๊ฐ€์ ธ์˜จ๋‹ค(์ถ”์ถœํ•œ๋‹ค).

    - ์ฟผ๋ฆฌ๋ฌธ์— ์˜ํ•ด ์กฐํšŒ๋œ ๋ฐ์ดํ„ฐ์˜ ํŠน์ • ์†์„ฑ๊ฐ’๋งŒ ๊ฐ€์ ธ์˜ฌ ์ˆ˜ ๋„ ์žˆ๋‹ค.

    - ์ฟผ๋ฆฌ๋ฌธ์— ์˜ํ•ด ๋ฐ˜ํ™˜๋œ ๋ฐ์ดํ„ฐ ๋ชฉ๋ก์€ IEnumerableํด๋ž˜์Šค๋ฅผ ์ƒ์†ํ•˜๊ธฐ์— foreach๋ฌธ์„ ์ด์šฉํ•ด ์ˆœํšŒํ•  ์ˆ˜ ์žˆ๋‹ค.
*/

namespace LinqEx
{
    class Member
    {
        public string name { get; set; }
        public int age { get; set; }

    }

    class Program
    {
        static void Main(string[] args)
        {
            Member[] ml =
            {
                new Member(){name = "ํ™๊ธธ๋™" , age =23},
                new Member(){name = "์ฒญ๊ธธ๋™" , age =24},
                new Member(){name = "๋ฐฑ๊ธธ๋™" , age =27},
                new Member(){name = "๋…น๊ธธ๋™" , age =25},
                new Member(){name = "๊ฒ€๊ธธ๋™" , age =26},
            };

            List<Member> list = new List<Member>();

            foreach (Member m in ml)
            {
                if (m.age >= 25)
                {
                    list.Add(m);
                }
            }

            list.Sort(
                (member1, member2) =>
                {
                    return member2.age - member1.age;
                }
                );


            foreach (Member m in list)
            {
                Console.WriteLine($"์ด๋ฆ„ : {m.name} ๋‚˜์ด : {m.age}");
            }

            // ์œ„์˜ ์ž‘์—…์„ LINQ ํ™œ์šฉ์‹œ.
            Console.WriteLine();
            Console.WriteLine("---------LINQํ™œ์šฉ----------");

            var ml2 = from member in ml
                      where member.age >= 25
                      orderby member.age
                      select new { member.name, age = member.age + "์„ธ" };

            foreach (var m in ml2)
            {
                Console.WriteLine($"์ด๋ฆ„ : {m.name} ๋‚˜์ด : {m.age}");
            }
        }
    }
}
Output

์ด๋ฆ„ : ๋ฐฑ๊ธธ๋™ ๋‚˜์ด : 27
์ด๋ฆ„ : ๊ฒ€๊ธธ๋™ ๋‚˜์ด : 26
์ด๋ฆ„ : ๋…น๊ธธ๋™ ๋‚˜์ด : 25

---------LINQํ™œ์šฉ----------
์ด๋ฆ„ : ๋…น๊ธธ๋™ ๋‚˜์ด : 25์„ธ
์ด๋ฆ„ : ๊ฒ€๊ธธ๋™ ๋‚˜์ด : 26์„ธ
์ด๋ฆ„ : ๋ฐฑ๊ธธ๋™ ๋‚˜์ด : 27์„ธ
  • 39์žฅ LINQ ์‚ฌ์šฉํ•ด๋ณด๊ธฐ ์ฝ”๋“œ์™€ ๋น„๊ต. => select ๋ถ€๋ถ„
    • ์ฟผ๋ฆฌ๋ฌธ์— ์˜ํ•ด ์กฐํšŒ๋œ ๋ฐ์ดํ„ฐ์˜ ํŠน์ • ์†์„ฑ๊ฐ’๋งŒ ๊ฐ€์ ธ์˜ฌ ์ˆ˜ ๋„ ์žˆ๋‹ค.
    • ์ฟผ๋ฆฌ๋ฌธ์— ์˜ํ•ด ๋ฐ˜ํ™˜๋œ ๋ฐ์ดํ„ฐ ๋ชฉ๋ก์€ IEnumerableํด๋ž˜์Šค๋ฅผ ์ƒ์†ํ•˜๊ธฐ์— foreach๋ฌธ์„ ์ด์šฉํ•ด ์ˆœํšŒํ•  ์ˆ˜ ์žˆ๋‹ค.

#### [LINQ] ๊ธฐ๋ณธ ๋ฌธ๋ฒ•
  • LINQ์˜ ์งˆ์˜ํ‘œํ˜„์‹ = ์ฟผ๋ฆฌ ์‹ (Query Expression) ์€ from ์ ˆ๋กœ ์‹œ์ž‘ํ•œ๋‹ค.

    • from ์ ˆ ๋‹ค์Œ์—๋Š” ๋ฐ์ดํ„ฐ ์›๋ณธ์ด ์˜จ๋‹ค. ๋ฐ์ดํ„ฐ ์›๋ณธ์€ ๋ฐฐ์—ด, ์ปฌ๋ ‰์…˜ ๋“ฑ์ด ์˜ฌ ์ˆ˜ ์žˆ๋‹ค.

    • ์ด๋•Œ from์ ˆ์—์„œ์˜ ๋งค๊ฐœ๋ณ€์ˆ˜๋Š” IEnumerable<T> ์˜ ํŒŒ์ƒํ˜•์‹์ด์–ด์•ผ ํ•œ๋‹ค.

    • from <๋ฒ”์œ„๋ณ€์ˆ˜> in <๋ฐ์ดํ„ฐ ์›๋ณธ>

      int[] aaa = {11,22,33,44,55}
      
      var res = from a in aaa
              where a % 2 != 0
              orderby a 
              select a;
    • where ์ ˆ์€ ๋ฒ”์œ„ ๋ณ€์ˆ˜์˜ ์กฐ๊ฑด์„ ์ง€์ •ํ•˜์—ฌ ๊ทธ ์กฐ๊ฑด์— ํ•ด๋‹นํ•˜๋Š” ๋ฐ์ดํ„ฐ๋ฅผ ๊ฑธ๋Ÿฌ๋‚ด๋Š” ์—ญํ• ์„ ํ•œ๋‹ค.
    • orderby์ ˆ์€ where ์ ˆ์—์„œ ๊ฑธ๋Ÿฌ๋‚ธ ๋ฐ์ดํ„ฐ๋ฅผ ์ •๋ ฌํ•˜๋Š” ์—ญํ• ์„ ํ•œ๋‹ค.
      • ๊ธฐ๋ณธ ์ •๋ ฌ๊ฐ’์€ ์˜ค๋ฆ„์ฐจ์ˆœ ascending ์œผ๋กœ ์ง€์ •๋˜์–ด ์žˆ๋‹ค. ๋‚ด๋ฆผ์ฐจ์ˆœ์€ descending
    • select ์ ˆ์€ ์งˆ์˜(Query)์˜ ์ตœ์ข… ๊ฒฐ๊ณผ๋ฅผ ๊ฐ€์ ธ์˜จ๋‹ค(์ถ”์ถœํ•œ๋‹ค).
    • LINQ์—์„œ ๋ฐ˜ํ™˜๋˜๋Š” ๊ฒฐ๊ณผ IEnumerable<T> ์ธ๋ฐ T๋Š” select ์ ˆ์—์„œ์˜ ๋ฐ˜ํ™˜๊ฒฐ๊ณผ ํ˜•์‹์ด๋‹ค.
    • ๋งŒ์ผ select์ ˆ์„ ์‚ฌ์šฉํ•˜์ง€ ์•Š์œผ๋ฉด where์ ˆ์— ์˜ํ•ด ํ•„ํ„ฐ๋ง๋œ ์ปฌ๋ ‰์…˜ ์›๋ณธ์ด ๋‚˜์˜ค๊ฒŒ ๋œ๋‹ค. ์ด๋•Œ์˜ ํƒ€์ž…์€ IEnumerable<T> ์ด๋ฉฐ, ๋‹จ์ˆœํžˆ ์ˆœํšŒ๋ฅผ ํ•˜๋ฉด์„œ ๊ฐ’์„ ์ฐธ์กฐํ• ๊ฒƒ์ด๋ผ๋ฉด ๋ณ€ํ™˜์ด ํ•„์š”์—†์ง€๋งŒ List ํ˜น์€ Dictionary๋กœ ๋ณ€ํ™˜ํ•ด์•ผํ•œ๋‹ค๋ฉด ToList() ํ˜น์€ ToDictionary()๋ฅผ ์‚ฌ์šฉํ•ด ๋ณ€ํ™˜ํ•ด์ค€๋‹ค.

'๐Ÿ’ป Programming Language > C#' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

42. LINQ ์„ธ๋ถ€ ๋ฌธ๋ฒ•  (0) 2022.04.08
41. ์ต๋ช… Type  (0) 2022.04.08
39. LINQ ์‚ฌ์šฉํ•ด๋ณด๊ธฐ  (0) 2022.04.08
38. ๋žŒ๋‹ค์‹(Lambda Expression)  (0) 2022.04.08
37. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ํ†ตํ•œ ์ด๋ฒคํŠธ ์ฒ˜๋ฆฌ  (0) 2022.04.08
'๐Ÿ’ป Programming Language/C#' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • 42. LINQ ์„ธ๋ถ€ ๋ฌธ๋ฒ•
  • 41. ์ต๋ช… Type
  • 39. LINQ ์‚ฌ์šฉํ•ด๋ณด๊ธฐ
  • 38. ๋žŒ๋‹ค์‹(Lambda Expression)
S.Honey
S.Honey
  • S.Honey
    Algo ์“ฐ์ž
    S.Honey
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (123)
      • ํšŒ๊ณ  (0)
        • ์ทจ์—… ํ›„ ํšŒ๊ณ  (0)
      • ๐Ÿƒ Frontend Road-Map (2)
        • ๐Ÿšฉ Summary (1)
        • ๐Ÿ“š Road-Map Contents (1)
        • ๐ŸŸง HTML (0)
        • ๐ŸŸฆ CSS (0)
        • ๐ŸŸจ Javascript (0)
        • โฌœ React (0)
        • ๐ŸŸช Redux (0)
      • Backend (0)
        • QueryDSL (0)
      • ๐Ÿ’ป Programming Language (54)
        • C# (51)
        • Flutter-Dart (3)
        • Java (0)
      • ๐Ÿ“š Computer Science (4)
        • Algorithms (4)
        • Database (0)
        • Network (0)
        • Operating System(OS) (0)
      • ๐Ÿ’ฏ CodingTest (60)
        • BaekJoon (22)
        • Programmers (34)
        • CodeTree (4)
      • โœ’๏ธ Design Pattern (1)
      • ๐Ÿฑ Etc (2)
        • Jenkins Plugin ์ œ์ž‘๊ธฐ (1)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

    • ๊ณต์ง€์‚ฌํ•ญ

      • ๐Ÿ“– ๊ณต๋ถ€ ์ฐธ๊ณ  ๊ต์žฌ ๋ฐ ์ž๋ฃŒ
    • ์ธ๊ธฐ ๊ธ€

    • ํƒœ๊ทธ

      ํŒŒ์ด์ฌ
      ๊ตฌํ˜„
      ์•Œ๊ณ ๋ฆฌ์ฆ˜
      ์Šคํ„ฐ๋””
      programmers
      ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค
      ์ด์ง„ํƒ์ƒ‰
      ๋™์  ํ”„๋กœ๊ทธ๋ž˜๋ฐ
      Flutter
      DART
      ๋ฐฑ์ค€
      ์‹œ๋ฎฌ๋ ˆ์ด์…˜
      ๋ฌธ์ž์—ด ํŒŒ์‹ฑ
      Algorithm
      ์“ฐ์…จ์ž–์•„
      ์ž๋ฃŒ๊ตฌ์กฐ
      ์‚ผ์„ฑsw์—ญํ…Œ
      ๊ทธ๋ž˜ํ”„ ํƒ์ƒ‰
      ์ฝ”๋“œํŠธ๋ฆฌ
      BAEKJOON
      ์ฝ”๋”ฉํ…Œ์ŠคํŠธ
      JS
      ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      sort
      JavaScript
      Java
      c#
      DP
      ์นด์นด์˜ค
      BFS
    • ์ตœ๊ทผ ๋Œ“๊ธ€

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    40. LINQ ๊ธฐ๋ณธ ๋ฌธ๋ฒ•
    ์ƒ๋‹จ์œผ๋กœ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”