39. LINQ ์‚ฌ์šฉํ•ด๋ณด๊ธฐ

2022. 4. 8. 09:15ยท๐Ÿ’ป Programming Language/C#
  • LINQ, ORM => SQL๋ฌธ๊ณผ๋Š” ๋‹ค๋ฅด๊ฒŒ DB๋กœ๋ถ€ํ„ฐ ํ•„์š”ํ•œ ๋ฐ์ดํ„ฐ๋ฅผ ํŽธ๋ฆฌํ•˜๊ฒŒ ๊ฐ€์ ธ์˜ด.

  • LINQ(Language Integrated Query) : C# ์–ธ์–ด์— ํ†ตํ•ฉ๋œ ๋ฐ์ดํ„ฐ ์งˆ์˜ ๊ธฐ๋Šฅ


using System.Collections;

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;
                    }
                );//์ด๋ถ€๋ถ„ ์ดํ•ด ํ™•์‹คํžˆํ•˜๊ณ  ๋„˜์–ด๊ฐ€๊ธฐ.
                // member2์—์„œ member1์„ ๋บ€๊ฐ’์ด ์–‘์ˆ˜์ผ๋•Œ๋งŒ ๋ฐ”๊ฟ”์ฃผ๋ฏ€๋กœ 
                // member2๊ฐ€ ๋” ํด๋•Œ๋งŒ ์œ„์น˜๋ฅผ ๋ฐ”๊ฟ”์คŒ
                //๋”ฐ๋ผ์„œ ํฐ์ˆ˜๋ถ€ํ„ฐ ์•ž์—์„œ ์ •๋ ฌ๋˜๋ฏ€๋กœ ๋‚ด๋ฆผ์ฐจ์ˆœ์ด๋จ.


            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 member;

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

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

---------LINQํ™œ์šฉ----------
์ด๋ฆ„ : ๋…น๊ธธ๋™ ๋‚˜์ด : 25
์ด๋ฆ„ : ๊ฒ€๊ธธ๋™ ๋‚˜์ด : 26
์ด๋ฆ„ : ๋ฐฑ๊ธธ๋™ ๋‚˜์ด : 27
  • LINQ๋ฅผ ํ™œ์šฉํ•˜๋ฉด ๊ธฐ์กด์— ๋ณต์žกํ•˜๋˜ ๋ฐ์ดํ„ฐ ์ถ”์ถœ ์ฝ”๋“œ๋„ ๊ฐ„๋‹จํ•˜๊ฒŒ ์ž‘์„ฑํ•  ์ˆ˜ ์žˆ๋‹ค.

โญ๏ธโญ๏ธโญ๏ธ ๋žŒ๋‹ค(Lambda)์‹์„ ์ด์šฉํ•œ Sort() ํ™œ์šฉ

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

// ํ•ด๋‹น ์ฝ”๋“œ๋Š” ์œ„์˜ ์ฝ”๋“œ์—์„œ ๋‚ด๋ฆผ์ฐจ์ˆœ ์ •๋ ฌ์„ ํ•ด์ฃผ๋Š” ํ•จ์ˆ˜

-Sort()ํ•จ์ˆ˜๋Š” ๋‘๋ฒˆ์งธ ์ธ์ž๋กœ ๋žŒ๋‹ค์‹์„ ๋งค๊ฐœ๋ณ€์ˆ˜๋กœ ๊ฐ€์งˆ ์ˆ˜ ์žˆ์Œ.

  • ๋žŒ๋‹ค์‹์€ ๋‘ ๊ฐœ์˜ ์š”์†Œ๋ฅผ ๋น„๊ตํ•  ๋•Œ ์‚ฌ์šฉ๋จ.
  • ๊ฐ„๋‹จํ•˜๊ฒŒ ๋งํ•ด์„œ ๋žŒ๋‹ค์‹์˜ ๋ฐ˜ํ™˜๊ฐ’์— ๋”ฐ๋ผ ๋‘ ๊ฐ’์˜ ์œ„์น˜๋ฅผ ๋ฐ”๊ฟ€์ง€ ๋ง์ง€๋ฅผ ๊ฒฐ์ •ํ•œ๋‹ค.
1. ๋žŒ๋‹ค์‹์˜ ๋ฐ˜ํ™˜๊ฐ’์ด "์–‘์ˆ˜" ์ด๋ฉด ์œ„์น˜๋ฅผ ๋ฐ”๊พผ๋‹ค.
2. ๋žŒ๋‹ค์‹์˜ ๋ฐ˜ํ™˜๊ฐ’์ด "0 ํ˜น์€ ์Œ์ˆ˜" ์ด๋ฉด ๊ทธ๋Œ€๋กœ ๋‘”๋‹ค.

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

41. ์ต๋ช… Type  (0) 2022.04.08
40. LINQ ๊ธฐ๋ณธ ๋ฌธ๋ฒ•  (0) 2022.04.08
38. ๋žŒ๋‹ค์‹(Lambda Expression)  (0) 2022.04.08
37. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ํ†ตํ•œ ์ด๋ฒคํŠธ ์ฒ˜๋ฆฌ  (0) 2022.04.08
36. ์ต๋ช…๋ฉ”์†Œ๋“œ  (0) 2022.04.08
'๐Ÿ’ป Programming Language/C#' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • 41. ์ต๋ช… Type
  • 40. LINQ ๊ธฐ๋ณธ ๋ฌธ๋ฒ•
  • 38. ๋žŒ๋‹ค์‹(Lambda Expression)
  • 37. ๋ธ๋ฆฌ๊ฒŒ์ดํŠธ๋ฅผ ํ†ตํ•œ ์ด๋ฒคํŠธ ์ฒ˜๋ฆฌ
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)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

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

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

    • ํƒœ๊ทธ

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

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    39. LINQ ์‚ฌ์šฉํ•ด๋ณด๊ธฐ
    ์ƒ๋‹จ์œผ๋กœ

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