๐Ÿ“–
Kyu9's Repo
  • Library of mameil
  • ์ด์Šˆ ๊ฒฝํ—˜
    • 20230220_ํŠธ๋žœ์žญ์…˜
    • 20230306_์บ์‹ฑ์ด์Šˆ
    • 20230722_ํ…Œ์ŠคํŠธ์ฝ”๋“œ์—์„œ @Transactional
    • 20230807_deadlock
  • ์ธํ„ด ์Šคํ„ฐ๋””
    • Gradle
    • Stream, Optional, ๋žŒ๋‹ค์‹
    • JVM์˜ ๋ฉ”๋ชจ๋ฆฌ ๊ตฌ์กฐ, Garbage Collector
    • RESTful API
    • Microservice Architecture
    • HTTP
    • ์›น์„œ๋ฒ„๋ž€ ๋ฌด์—‡์ธ๊ฐ€
    • Git Branch
    • TDD
    • Redis์„ ์ด์šฉํ•œ ์บ์‹œ
    • Thymeleaf
    • ์ •๋ฆฌ๊ฐ€ ํ•„์š”ํ•œ ์ž๋ฃŒ๋“ค
    • SpringBoot Management
    • ํ…Œ์Šคํฌ ์ฝ”๋“œ ๋ถ„ํ• 
  • ๋™์•„๋ฆฌ ์Šคํ„ฐ๋””
    • ๊ธฐ๋ณธ SQL ๊ณต๋ถ€
      • SQL์˜ ๊ธฐ๋ณธ ๊ฐœ๋…
      • SELECT ๋ฌธ์žฅ์„ ์ด์šฉํ•˜์—ฌ ์›ํ•˜๋Š” ๋ฐ์ดํ„ฐ ์ถœ๋ ฅํ•˜๊ธฐ
        • ์ง‘ํ•ฉ ์—ฐ์‚ฐ์ž ์‚ฌ์šฉํ•˜๊ธฐ
        • where์ ˆ์— ๋น„๊ต ์—ฐ์‚ฐ์ž๋ฅผ ์‚ฌ์šฉํ•ด๋ณด๊ธฐ
        • SELECT_EX
        • ์‚ฐ์ˆ  ์—ฐ์‚ฐ์ž ์‚ฌ์šฉํ•ด๋ณด๊ธฐ
      • ๋‹จ์ผ ํ–‰ ํ•จ์ˆ˜ ์‚ฌ์šฉ
        • lower/upper ํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • lengthํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • concatํ•จ์ˆ˜ ์‚ฌ์šฉ
        • substr/mid/substring ํ•จ์ˆ˜ ์‚ฌ์šฉ
        • instrํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • lpad/rpad ํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • trim/ltrim/rtrim ํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • replace ํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • round ํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • truncate ํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • modํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • ceilํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • floorํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • power ํ•จ์ˆ˜ ์‚ฌ์šฉํ•˜๊ธฐ
        • Date fn(๋‚ ์งœ ํ•จ์ˆ˜)
        • ํ˜• ๋ณ€ํ™˜ ํ•จ์ˆ˜
        • ์ผ๋ฐ˜ํ•จ์ˆ˜๋ž€
    • a-ha ์‹ค์Šต
    • ํ˜ผ์ž์„œ ๋งŒ๋“ค์–ด๋ณธ ๊ฒŒ์‹œํŒ
    • AWS ๊ฐ•์˜
  • ํ•™๊ต ๋‚˜๋จธ์ง€ ๊ณต๋ถ€ ์ž๋ฃŒ
    • ์›นํ”„๋ ˆ์ž„์›Œํฌ(Spring)
      • Spring์ด๋ž€?
      • Webframework1-1
      • Webframework1-2
      • SpringBoot์˜ ํŠน์ง•
      • SpringBoot ์ƒ์„ฑ ๋ฐฉ๋ฒ•
      • Spring Data JPA
      • SpringBoot Security
      • SpringBoot HATEOAS
  • ๊ณต๋ถ€ ์ž๋ฃŒ๋“ค
  • WS ์˜จ๋ผ์ธ ์ž๋ฐ” ์Šคํ„ฐ๋””
    • Week1(JVM์€ ๋ฌด์—‡์ด๋ฉฐ ์ž๋ฐ” ์ฝ”๋“œ๋Š” ์–ด๋–ป๊ฒŒ ์‹คํ–‰ํ•˜๋Š” ๊ฒƒ์ธ๊ฐ€.)
    • Week2(์ž๋ฐ” ๋ฐ์ดํ„ฐ ํƒ€์ž…, ๋ณ€์ˆ˜ ๊ทธ๋ฆฌ๊ณ  ๋ฐฐ์—ด)
    • Week3(์—ฐ์‚ฐ์ž)
    • Week4(์ œ์–ด๋ฌธ)
    • Week5(ํด๋ž˜์Šค)
    • Week6(์ƒ์†)
    • Week7(ํŒจํ‚ค์ง€)
    • Week8(์ธํ„ฐํŽ˜์ด์Šค)
    • Week9(์˜ˆ์™ธ์ฒ˜๋ฆฌ)
    • Week10(๋ฉ€ํ‹ฐ์“ฐ๋ ˆ๋“œ ํ”„๋กœ๊ทธ๋ž˜๋ฐ)
    • Week11(Enum)
    • Week12(Annotation)
    • Week13(I/O)
    • Week14(Generic)
    • Week15(๋žŒ๋‹ค์‹)
  • ๋ฐฑ์ค€๋ฌธ์ œ
    • ์ž…์ถœ๋ ฅ๊ณผ ์‚ฌ์น™์—ฐ์‚ฐ
      • We love kriii(10718)
      • ๊ณ ์–‘์ด(10171)
      • ๊ฐœ(10172)
      • A+B(1000)
      • A-B(1001)
      • AxB(10998)
      • A/B(1008)
      • ์‚ฌ์น™์—ฐ์‚ฐ(10869)
      • ๋‚˜๋จธ์ง€(10430)
      • ๊ณฑ์…ˆ(2588)
    • for๋ฌธ
      • ๊ตฌ๊ตฌ๋‹จ(2739)
      • A+B - 3(10950)
      • ํ•ฉ(8393)
      • ๋น ๋ฅธ A+B(15552)
      • N ์ฐ๊ธฐ(2741)
      • ๊ธฐ์ฐ N(2742)
      • A+B - 7(11021)
      • A+B - 8(11022)
      • ๋ณ„ ์ฐ๊ธฐ - 1(2438)
      • ๋ณ„ ์ฐ๊ธฐ - 2(2439)
      • X๋ณด๋‹ค ์ž‘์€ ์ˆ˜(10871)
    • if๋ฌธ
      • ๋‘ ์ˆ˜ ๋น„๊ตํ•˜๊ธฐ(1330)
      • ์‹œํ—˜ ์„ฑ์ (9498)
      • ์œค๋…„(2753)
      • ์‚ฌ๋ถ„๋ฉด ๊ณ ๋ฅด๊ธฐ(14681)
      • ์•Œ๋žŒ ์‹œ๊ณ„(2884)
      • ์˜ค๋ธ ์‹œ๊ณ„(2525)
      • ์ฃผ์‚ฌ์œ„ ์„ธ๊ฐœ(2480)
      • ์˜์ˆ˜์ฆ(25304)
    • While๋ฌธ
      • A+B - 5(10952)
      • A+B - 4(10951)
      • ๋”ํ•˜๊ธฐ ์‚ฌ์ดํด(1110)
    • 1์ฐจ์› ๋ฐฐ์—ด
      • ์ตœ์†Œ, ์ตœ๋Œ€(10818)
      • ์ตœ๋Œ“๊ฐ’(2562)
      • ์ˆซ์ž์˜ ๊ฐœ์ˆ˜(2577)
      • ๋‚˜๋จธ์ง€(3052)
      • ํ‰๊ท (1546)
      • OXํ€ด์ฆˆ(8958)
      • ํ‰๊ท ์€ ๋„˜๊ฒ ์ง€(4344)
    • ํ•จ์ˆ˜
      • ์ •์ˆ˜N๊ฐœ์˜ ํ•ฉ(15596)
      • ์…€ํ”„ ๋„˜๋ฒ„(4673)
      • ํ•œ์ˆ˜(1065)
    • ๋ฌธ์ž์—ด
      • ์•„์Šคํ‚ค์ฝ”๋“œ(11654)
      • ์ˆซ์ž์˜ ํ•ฉ(11720)
      • ์•ŒํŒŒ๋ฒณ ์ฐพ๊ธฐ(10809)
      • ๋ฌธ์ž์—ด ๋ฐ˜๋ณต(2675)
      • ๋‹จ์–ด ๊ณต๋ถ€(1157)
      • ๋‹จ์–ด์˜ ๊ฐœ์ˆ˜(1152)
      • ์ƒ์ˆ˜(2908)
      • ๋‹ค์ด์–ผ(5622)
      • ํฌ๋กœ์•„ํ‹ฐ์•„ ์•ŒํŒŒ๋ฒณ(2941)
      • ๊ทธ๋ฃน ๋‹จ์–ด ์ฒด์ปค(1316)
    • ๊ธฐ๋ณธ์ˆ˜ํ•™-1
      • ์†์ต๋ถ„๊ธฐ์ (1712)
      • ๋ฒŒ์ง‘(2292)
      • ๋ถ„์ˆ˜์ฐพ๊ธฐ(1193)
      • ๋‹ฌํŒฝ์ด๋Š” ์˜ฌ๋ผ๊ฐ€๊ณ  ์‹ถ๋‹ค(2869)
      • ACM ํ˜ธํ…”(10250)
      • ๋ถ€๋…€ํšŒ์žฅ์ด ๋ ํ…Œ์•ผ(2775)
      • ์„คํƒ• ๋ฐฐ๋‹ฌ(2839)
      • ํฐ ์ˆ˜ A+B(10757)
      • Fly me to the Alpha Centauri(1011)
    • ๊ธฐ๋ณธ์ˆ˜ํ•™-2
      • ์†Œ์ˆ˜ ์ฐพ๊ธฐ(1978)
      • ์†Œ์ˆ˜(2581)
      • ์†Œ์ธ์ˆ˜๋ถ„ํ•ด(11653)
      • ์†Œ์ˆ˜ ๊ตฌํ•˜๊ธฐ(1929)
      • ๋ฒ ๋ฅดํŠธ์™€ ๊ณต์กด(4948)
    • ์žฌ๊ท€
      • ํ•˜๋…ธ์ด ํƒ‘ ์ด๋™ ์ˆœ์„œ(11729)
      • ํ”ผ๋ณด๋‚˜์น˜ ์ˆ˜ 5(10870)
      • ๋ณ„ ์ฐ๊ธฐ(2447)
    • ๋ธŒ๋ฃจํŠธ ํฌ์Šค
      • ๋ธ”๋ž™์žญ(2798)
      • ๋ถ„ํ•ดํ•ฉ(2231)
      • ๋ฉ์น˜(7568)
      • ์ฒด์ŠคํŒ ๋‹ค์‹œ ์น ํ•˜๊ธฐ(1018)
      • ์˜ํ™”๊ฐ๋… ์Š˜(1436)
    • ์ง‘ํ•ฉ๊ณผ ๋งต
      • ์ˆซ์ž ์นด๋“œ(10815)
      • ๋ฌธ์ž์—ด ์ง‘ํ•ฉ(14425)
      • ์ˆซ์ž ์นด๋“œ2(10816)
      • ๋“ฃ๋ณด์žก(1764)
      • ๋Œ€์นญ ์ฐจ์ง‘ํ•ฉ(1269)
      • ์„œ๋กœ ๋‹ค๋ฅธ ๋ถ€๋ถ„ ๋ฌธ์ž์—ด ๊ฐฏ์ˆ˜(11478)
    • ์ •๋ ฌ
      • ์ˆ˜ ์ •๋ ฌํ•˜๊ธฐ(2750)
      • ์ˆ˜ ์ •๋ ฌํ•˜๊ธฐ 2(2751)
      • ์ˆ˜ ์ •๋ ฌํ•˜๊ธฐ 3(10989)
      • ํ†ต๊ณ„ํ•™(2108)
      • ์†ŒํŠธ์ธ์‚ฌ์ด๋“œ(1427)
      • ์ขŒํ‘œ ์ •๋ ฌํ•˜๊ธฐ(11650)
      • ์ขŒํ‘œ ์ •๋ ฌํ•˜๊ธฐ2(11651)
      • ๋‹จ์–ด ์ •๋ ฌ(1181)
      • ๋‚˜์ด์ˆœ ์ •๋ ฌ(10814)
      • ์ปคํŠธ๋ผ์ธ(25305)
      • ์ขŒํ‘œ์••์ถ•(18870)
    • ๋ฐฑํŠธ๋ž˜ํ‚น
      • N๊ณผ M - 1(15649)
      • N๊ณผ M - 2(15650)
      • N๊ณผ M - 3(15651)
      • N๊ณผ M - 4(15652)
      • N-Queen(9663)
      • ์Šค๋„์ฟ (2580)
      • ์—ฐ์‚ฐ์ž ๋ผ์›Œ๋„ฃ๊ธฐ(14888)
      • ์Šคํƒ€ํŠธ์™€ ๋งํฌ(14889)
    • ์ด๋ถ„ ํƒ์ƒ‰
      • ์ˆ˜ ์ฐพ๊ธฐ(1920)
    • ๋™์ ๊ณ„ํš๋ฒ•
      • ํ”ผ๋ณด๋‚˜์น˜ ํ•จ์ˆ˜(1003)
      • ์‹ ๋‚˜๋Š” ํ•จ์ˆ˜ ์‹คํ–‰(9184)
      • 01ํƒ€์ผ(1904)
      • ํŒŒ๋„๋ฐ˜ ์ˆ˜์—ด(9461)
      • RGB๊ฑฐ๋ฆฌ(1149)
      • ์ •์ˆ˜ ์‚ผ๊ฐํ˜•(1932)
      • ๊ณ„๋‹จ ์˜ค๋ฅด๊ธฐ(2579)
      • 1๋กœ ๋งŒ๋“ค๊ธฐ(1463)
      • ์‰ฌ์šด ๊ณ„๋‹จ ์ˆ˜(10844)
      • ํฌ๋„์ฃผ ์‹œ์‹(2156)
      • ๊ฐ€์žฅ ๊ธด ์ฆ๊ฐ€ํ•˜๋Š” ๋ถ€๋ถ„ ์ˆ˜์—ด(11053)
      • ๊ฐ€์žฅ ๊ธด ๋ฐ”์ดํ† ๋‹‰ ๋ถ€๋ถ„ ์ˆ˜์—ด(11504)
      • ์ „๊นƒ์ค„(2565)
      • LCS(9251)
      • ์—ฐ์†ํ•ฉ(1912)
      • ํ‰๋ฒ”ํ•œ ๋ฐฐ๋‚ญ(12865)
      • ๋”ํ•˜๊ธฐ(9095)
    • DFS์™€ BFS
      • ๋ฏธ๋กœํƒ์ƒ‰(2178)
      • ๋ฐ”์ด๋Ÿฌ์Šค(2606)
      • DFS์™€ BFS(1260)
      • ๋‹จ์ง€๋ฒˆํ˜ธ๋ถ™์ด๊ธฐ(2667)
      • ์ „์Ÿ - ์ „ํˆฌ(1303)
      • ์ˆจ๋ฐ”๊ผญ์งˆ(1697)
      • ๋ฐ์Šค ๋‚˜์ดํŠธ(16948)
      • ๋‚˜์ดํŠธ์˜ ์ด๋™(7562)
      • ๋…น์ƒ‰ ์˜ท ์ž…์€ ์• ๊ฐ€ ์ ค๋‹ค์ง€?(4485)
      • ์Œ์‹๋ฌผ ํ”ผํ•˜๊ธฐ(1743)
      • A->B (16953)
      • ์ˆจ๋ฐ”๊ผญ์งˆ 3(13549)
      • ์ˆจ๋ฐ”๊ผญ์งˆ 2(12851)
    • ๊ตฌํ˜„
      • ์น˜์ฆˆ(2636)
  • ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค ๋ฌธ์ œ
    • SQL
      • Animal Table - Oracle
      • Animal Table - MySQL
      • Animal Table2 - Oracle
      • Animal Table 3,4 - Oracle
    • Lv1
      • ๋‘ ๊ฐœ ๋ฝ‘์•„์„œ ๋”ํ•˜๊ธฐ
      • ์ œ์ผ ์ž‘์€ ์ˆ˜ ์ œ๊ฑฐํ•˜๊ธฐ
      • ๋ฌธ์ž์—ด ๋‚ด p์™€ y์˜ ๊ฐœ์ˆ˜
      • ์˜ˆ์‚ฐ
      • ์ž๋ฆฟ์ˆ˜ ๋”ํ•˜๊ธฐ
      • ๋‘ ์ •์ˆ˜ ์‚ฌ์ด์˜ ํ•ฉ
      • ๊ฐ™์€ ์ˆซ์ž๋Š” ์‹ซ์–ด
      • ๊ฐ€์šด๋ฐ ๊ธ€์ž ๊ฐ€์ ธ์˜ค๊ธฐ
      • ์ˆ˜๋ฐ•์ˆ˜๋ฐ•์ˆ˜๋ฐ•์ˆ˜๋ฐ•์ˆ˜๋ฐ•์ˆ˜?
      • ๋‚˜๋ˆ„์–ด ๋–จ์–ด์ง€๋Š” ์ˆซ์ž ๋ฐฐ์—ด
      • 2016๋…„
      • ํฐ์บฃ๋ชฌ
      • ์„œ์šธ์—์„œ ๊น€์„œ๋ฐฉ ์ฐพ๊ธฐ
      • ๋ฌธ์ž์—ด์„ ์ •์ˆ˜๋กœ ๋ฐ”๊พธ๊ธฐ
      • ์†Œ์ˆ˜ ๋งŒ๋“ค๊ธฐ
      • ๋ฌธ์ž์—ด ๋‹ค๋ฃจ๊ธฐ ๊ธฐ๋ณธ
      • ์†Œ์ˆ˜ ์ฐพ๊ธฐ(์—๋ผํ† ์Šคํ…Œ๋„ค์Šค์˜ ์ฒด)
      • ์ˆซ์ž ๋ฌธ์ž์—ด๊ณผ ์˜๋‹จ์–ด
      • ์ด์ƒํ•œ ๋ฌธ์ž ๋งŒ๋“ค๊ธฐ
      • ์—†๋Š” ์ˆซ์ž ๋”ํ•˜๊ธฐ
      • ๋ฌธ์ž์—ด ๋‚ด๋ฆผ์ฐจ์ˆœ์œผ๋กœ ๋ฐฐ์น˜ํ•˜๊ธฐ
      • ๋ฌธ์ž์—ด ๋‚ด ๋งˆ์Œ๋Œ€๋กœ ์ •๋ ฌํ•˜๊ธฐ
      • ์•ฝ์ˆ˜์˜ ๊ฐœ์ˆ˜์™€ ๋ง์…ˆ
      • ์ฝœ๋ผ์ธ  ์ถ”์ธก
      • ์ž์—ฐ์ˆ˜ ๋’ค์ง‘์–ด ๋ฐฐ์—ด๋กœ ๋งŒ๋“ค๊ธฐ
      • ์‹ ๊ทœ ์•„์ด๋”” ์ถ”์ฒœ
      • ๋น„๋ฐ€์ง€๋„
      • ํฌ๋ ˆ์ธ ์ธํ˜•๋ฝ‘๊ธฐ ๊ฒŒ์ž„
      • ์‹คํŒจ์œจ
      • ๋กœ๋˜์˜ ์ตœ๊ณ  ์ˆœ์œ„์™€ ์ตœ์ € ์ˆœ์œ„
      • ํ‚คํŒจ๋“œ ๋ˆ„๋ฅด๊ธฐ
      • ์ •์ˆ˜ ๋‚ด๋ฆผ์ฐจ์ˆœ์œผ๋กœ ๋ฐฐ์น˜ํ•˜๊ธฐ
    • Lv2
      • ํ–‰๋ ฌ์˜ ๊ณฑ์…ˆ
      • ์˜์–ด ๋๋ง์ž‡๊ธฐ
      • ์˜์–ด ๋๋ง์ž‡๊ธฐ
      • N๊ฐœ์˜ ์ตœ์†Œ ๊ณต๋ฐฐ์ˆ˜
      • ํ”ผ๋ณด๋‚˜์น˜ ์ˆ˜
      • 124 ๋‚˜๋ผ์˜ ์ˆซ์ž
      • ์ง์ง€์–ด ์ œ๊ฑฐํ•˜๊ธฐ
      • ํ”„๋ฆฐํ„ฐ
      • ๋‹ค์Œ ํฐ ์ˆซ์ž
      • ์ตœ๋Œ“๊ฐ’๊ณผ ์ตœ์†Ÿ๊ฐ’
      • ์ตœ์†Œ๊ฐ’ ๋งŒ๋“ค๊ธฐ
      • ์ˆซ์ž์˜ ํ‘œํ˜„
      • JadenCase ๋ฌธ์ž์—ด ๋งŒ๋“ค๊ธฐ
      • ์˜คํ”ˆ์ฑ„ํŒ…๋ฐฉ
      • ์˜์–ด ๋๋ง์ž‡๊ธฐ
      • ๋ฉ€์ฉกํ•œ ์‚ฌ๊ฐํ˜•
      • ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ
      • ์œ„์žฅ
      • ๊ธฐ๋Šฅ๊ฐœ๋ฐœ
      • ๋” ๋งต๊ฒŒ
      • ์Šคํ‚ฌํŠธ๋ฆฌ
    • ์™„์ „ํƒ์ƒ‰
      • ๋ชจ์˜๊ณ ์‚ฌ(Lv1)
      • ์นดํŽซ(Lv2)
      • ์†Œ์ˆ˜ ์ฐพ๊ธฐ(Lv2)
    • ์ •๋ ฌ(Sorting)
      • K๋ฒˆ์งธ ์ˆ˜(Lv1)
      • ๊ฐ€์žฅ ํฐ ์ˆ˜(Lv2)
      • H-Index(Lv2)
    • ํ•ด์‹œ(Hash)
      • ์™„์ฃผํ•˜์ง€ ๋ชปํ•œ ์„ ์ˆ˜(Lv1)
      • ์ „ํ™”๋ฒˆํ˜ธ ๋ชฉ๋ก(Lv2)
    • ํƒ์š•๋ฒ•(Greedy)
      • ์ฒด์œก๋ณต(Lv1)
      • ํฐ ์ˆ˜ ๋งŒ๋“ค๊ธฐ(Lv2)
      • ๊ตฌ๋ช…๋ณดํŠธ(Lv2)
    • ๋™์ ๊ณ„ํš๋ฒ•(DP)
      • ์ •์ˆ˜ ์‚ผ๊ฐํ˜•(Lv3)
    • ๊นŠ์ด/๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰(DFS/BFS)
      • ํƒ€๊ฒŸ ๋„˜๋ฒ„(Lv2)
      • ๋„คํŠธ์›Œํฌ(Lv3)
      • ๋‹จ์–ด ๋ณ€ํ™˜(Lv3)
  • ์Šคํ”„๋ง๋ถ€ํŠธ ์ฑ…
    • Day 1
    • Day 2
    • Day 3
    • Day 4
    • Day 5
    • Day 6
    • Day 7
    • Day 8
    • Day 9
    • Day 10
    • Day 11
    • Day 12
    • Day 13
    • Day 14
    • Day 15
    • Day 16
    • Day 17
  • JPA ์ฑ…
    • ํ”„๋กœ์ ํŠธ ์„ธํŒ… ๋ฐ ๊ธฐ๋ณธ์„ค์ •
    • ์˜์†์„ฑ ๊ด€๋ฆฌ ๊ฐœ๋…
    • ์—”ํ‹ฐํ‹ฐ ๋งคํ•‘
      • ์‹ค์Šต ์˜ˆ์ œ
    • ์—ฐ๊ด€๊ด€๊ณ„ ๋งคํ•‘ ๊ธฐ์ดˆ
      • ์‹ค์Šต ์˜ˆ์ œ
    • ๋‹ค์–‘ํ•œ ์—ฐ๊ด€๊ด€๊ณ„ ๋งคํ•‘
      • ๋‹ค๋Œ€์ผ, ์ผ๋Œ€๋‹ค ๊ด€๊ณ„
      • ์ผ๋Œ€์ผ, ๋‹ค๋Œ€๋‹ค ๊ด€๊ณ„
      • ์‹ค์Šต ์˜ˆ์ œ
    • ๊ณ ๊ธ‰ ๋งคํ•‘
      • ์ƒ์† ๊ด€๊ณ„ ๋งคํ•‘
      • @MappedSuperclass
      • ๋ณตํ•ฉ ํ‚ค์™€ ์‹๋ณ„ ๊ด€๊ณ„ ๋งคํ•‘
      • ์กฐ์ธ ํ…Œ์ด๋ธ”
    • ํ”„๋ก์‹œ์™€ ์—ฐ๊ด€๊ด€๊ณ„ ๊ด€๋ฆฌ
      • ํ”„๋ก์‹œ
      • ์ฆ‰์‹œ ๋กœ๋”ฉ๊ณผ ์ง€์—ฐ ๋กœ๋”ฉ
      • ์˜์†์„ฑ ์ „์ด, ๊ณ ์•„ ๊ฐ์ฒด
    • ๊ฐ’ ํƒ€์ž…
      • ์ž„๋ฒ ๋””๋“œ ํƒ€์ž…
      • ๊ฐ’ ํƒ€์ž…๊ณผ ๋ถˆ๋ณ€ ๊ฐ์ฒด
      • ๊ฐ’ ํƒ€์ž…์˜ ๋น„๊ต, ์ปฌ๋ ‰์…˜
    • ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ ์–ธ์–ด
      • JPQL part1
      • JPQL part2
      • JPQL part3
      • QueryDSL
      • NativeSQL
      • ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ ์‹ฌํ™”
    • ์‘์šฉ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜
      • ์—”ํ‹ฐํ‹ฐ ์„ค์ •
    • ์Šคํ”„๋ง ๋ฐ์ดํ„ฐ JPA
      • ๊ณตํ†ต ์ธํ„ฐํŽ˜์ด์Šค
  • Kotlin In Action
    • ์ฝ”ํ‹€๋ฆฐ์˜ ํŠน์ง•
    • ์ฝ”ํ‹€๋ฆฐ์˜ ๊ธฐ์ดˆ
    • ํ•จ์ˆ˜ ์ •์˜์™€ ํ˜ธ์ถœ
    • ํด๋ž˜์Šค, ๊ฐ์ฒด, ์ธํ„ฐํŽ˜์ด์Šค
    • ๋žŒ๋‹ค ๋ฐฉ์‹
    • ์ฝ”ํ‹€๋ฆฐ ํƒ€์ž… ์‹œ์Šคํ…œ
    • ์—ฐ์‚ฐ์ž ์˜ค๋ฒ„๋กœ๋”ฉ๊ณผ ๊ธฐํƒ€ ๊ด€๋ก€
    • ๊ณ ์ฐจํ•จ์ˆ˜
    • ์ œ๋„ค๋ฆญ์Šค
    • ์• ๋…ธํ…Œ์ด์…˜๊ณผ ๋ฆฌํ”Œ๋ ‰์…˜
    • ์ฝ”๋ฃจํ‹ด
  • Oracle
    • Oracle ๊ธฐ๋ณธ
    • Oracle ์‹ฌํ™”
  • SQL_์—ฐ์Šต
    • Revising the Select Query
    • Basic Select
    • Advanced Select
    • Basic Select 2
  • SQL ์ฒซ๊ฑธ์Œ(์ฑ…)
    • Day 1
    • Day 2
    • Day 3
    • Day 4
    • Day 5
    • Day 6
    • Day 7
    • Day 8
    • Day 9
    • Day 10
    • Day 11
    • Day 12
    • Day 13
    • Day 14
    • Day 15
    • Day 16
    • Day 17
    • Day 18
    • Day 19
    • Day 20
    • Day 21
    • Day 22
    • Day 23
    • Day 24
    • Day 25
    • Day 26
    • Day 27
    • Day 28
    • Day 29
    • Day 30
  • ๋” ์ž๋ฐ” ์ฝ”๋“œ๋ฅผ ์กฐ์ž‘ํ•˜๋Š” ๋‹ค์–‘ํ•œ ๋ฐฉ๋ฒ•
    • JVM ์ดํ•ดํ•˜๊ธฐ
    • ๋ฐ”์ดํŠธ์ฝ”๋“œ ์กฐ์ž‘
    • ๋ฆฌํ”Œ๋ ‰์…˜
    • ๋‹ค์ด๋‚˜๋ฏน ํ”„๋ก์‹œ
    • ์• ๋…ธํ…Œ์ด์…˜ ํ”„๋กœ์„ธ์„œ
  • ๋” ์ž๋ฐ”, ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ํ…Œ์ŠคํŠธํ•˜๋Š” ๋‹ค์–‘ํ•œ ๋ฐฉ๋ฒ•
    • JUnit5
    • Mockito
    • ๋„์ปค์™€ ํ…Œ์ŠคํŠธ
    • ์„ฑ๋Šฅ, ์šด์˜์ด์Šˆ, ์•„ํ‚คํ…์ฒ˜ ํ…Œ์ŠคํŠธ
  • ์ดํŽ™ํ‹ฐ๋ธŒ ์ž๋ฐ”
    • item1 - ์ƒ์„ฑ์ž ๋Œ€์‹  ์ •์  ํŒฉํ† ๋ฆฌ ๋ฉ”์†Œ๋“œ๋ฅผ ๊ณ ๋ คํ•˜๋ผ
    • item2 - ์ƒ์„ฑ์ž์— ๋งค๊ฐœ๋ณ€์ˆ˜๊ฐ€ ๋งŽ๋‹ค๋ฉด ๋นŒ๋”๋ฅผ ๊ณ ๋ คํ•˜๋ผ
    • item3 - ์ƒ์„ฑ์ž๋‚˜ ์—ด๊ฑฐํƒ€์ž…์œผ๋กœ ์‹ฑ๊ธ€ํ„ด์ž„์„ ๋ณด์ฆํ•˜๋ผ
    • item4 - ์ธ์Šคํ„ด์Šคํ™”๋ฅผ ๋ง‰๊ธฐ ์œ„ํ•ด์„  private ์ƒ์„ฑ์ž๋ฅผ ์‚ฌ์šฉํ•˜๋ผ
    • item5 - ์ž์›์„ ์ง์ ‘ ๋ช…์‹œํ•˜์ง€ ๋ง๊ณ  ์˜์กด ๊ฐ์ฒด ์ฃผ์ž…์„ ์‚ฌ์šฉํ•˜๋ผ
    • item6 - ๋ถˆํ•„์š”ํ•œ ๊ฐ์ฒด ์ƒ์„ฑ์„ ํ”ผํ•˜๋ผ
    • item7 - ๋‹ค ์“ด ๊ฐ์ฒด ์ฐธ์กฐ๋ฅผ ํ•ด์ œํ•˜๋ผ
    • item8 - finalizer์™€ cleaner ์‚ฌ์šฉ์„ ํ”ผํ•˜๋ผ
    • item9 - try-finally ๋ณด๋‹ค try-with-resources์„ ์‚ฌ์šฉํ•˜๋ผ
    • item10 - equals๋Š” ์ผ๋ฐ˜ ๊ทœ์•ฝ์„ ์ง€์ผœ ์žฌ์ •์˜ํ•˜๋ผ
    • item11 - equals์„ ์žฌ์ •์˜ํ•˜๋ ค๋ฉด hashCode๋„ ์žฌ์ •์˜ํ•˜๋ผ
    • item12 - toString์„ ํ•ญ์ƒ ์žฌ์ •์˜ํ•˜๋ผ
    • item13 - clone ์žฌ์ •์˜๋Š” ์ฃผ์˜ํ•ด์„œ ์ง„ํ–‰ํ•˜๋ผ
    • item14 - Comparable์„ ๊ตฌํ˜„ํ• ์ง€ ๊ณ ๋ฏผํ•˜๋ผ
  • Elastic Search
    • ๊ฐ•์˜ Summary
    • Elastic Summary ๊ฐœ๋… ์ •๋ฆฌ
    • Elastic Summary ์ ์šฉ ์ •๋ฆฌ
  • ํ† ๋น„์˜ ์Šคํ”„๋ง ๊ฐ•์˜
    • ์Šคํ”„๋ง๋ถ€ํŠธ ์‚ดํŽด๋ณด๊ธฐ
    • ๋…๋ฆฝ ์‹คํ–‰ํ˜• ์„œ๋ธ”๋ฆฟ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜
  • k8s
    • minikube ์„ค์น˜
    • jenkins ์ถ”๊ฐ€
  • Article
    • Choosing the Right MessageBroker
Powered by GitBook
On this page
  • ๊ธฐ๋ณธ ๋ฌธ๋ฒ•๊ณผ ์ฟผ๋ฆฌ API
  • SELECT ๋ฌธ
  • TypeQuery, Query
  • ํŒŒ๋ผ๋ฏธํ„ฐ ๋ฐ”์ธ๋”ฉ
  • ํ”„๋กœ์ ์…˜
  • ํŽ˜์ด์ง• API
  • ์ง‘ํ•ฉ๊ณผ ์ •๋ ฌ

Was this helpful?

  1. JPA ์ฑ…
  2. ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ ์–ธ์–ด

JPQL part1

์ด์ „์˜ ๋‹ค์–‘ํ•œ ๊ฒƒ๋“ค์„ ๋ดค๊ฒ ์ง€๋งŒ ์–ด๋–ค ๋ฐฉ์‹์„ ์‚ฌ์šฉํ•˜๋“  ํ•ญ์ƒ JPQL์ด ๋จผ์ €๋กœ ์‹œ์ž‘๋˜๊ฒŒ ๋œ๋‹ค ์ผ๋‹จ ํ•œ๋ฒˆ JPQL์˜ ํŠน์ง•์„ ์ •๋ฆฌํ•ด๋ณด์ž

  • JPQL์€ ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ ์–ธ์–ด์ด๋‹ค. ๋”ฐ๋ผ์„œ ํ…Œ์ด๋ธ”์„ ๋Œ€์ƒ์œผ๋กœ ์ฟผ๋ฆฌํ•˜๋Š” ๊ฒƒ์ด ์•„๋‹ˆ๋ผ ์—”ํ‹ฐํ‹ฐ ๊ฐ์ฒด๋ฅผ ๋Œ€์ƒ์œผ๋กœ ์ฟผ๋ฆฌ

  • JPQL์€ SQL์„ ์ถ”์ƒํ™”ํ•ด์„œ ํŠน์ • ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค SQL์— ์˜์กดํ•˜์ง€ ์•Š์Œ

  • JPQL๋„ ๊ฒฐ๊ตญ์€ SQL๋กœ ๋ฐ˜ํ™˜๋œ๋‹ค๋Š” ์ 

๊ธฐ๋ณธ ๋ฌธ๋ฒ•๊ณผ ์ฟผ๋ฆฌ API

JPQL๋„ SQL๊ณผ ๋น„์Šทํ•˜๊ฒŒ select, update, delete๋ฌธ์„ ์‚ฌ์šฉํ•˜๋Š” ๊ฒƒ์ด ๊ฐ€๋Šฅํ•˜๋‹ค :๊ทผ๋ฐ insert๋Š” ์™œ ์—†๋ƒ? -> EntityManager.persist()๋กœ ์ €์žฅํ•˜๋ฉด ๋˜๋‹ˆ๊นŒ

SELECT ๋ฌธ

์˜ˆ์‹œ๋ฅผ ๋ด๋ณผ๊นŒ

SELECT m FROM Member AS m where m.username = 'Hello'

ํŠน์ง•๋ณ„๋กœ ๋ณด์ž

๋Œ€์†Œ๋ฌธ์ž ๊ตฌ๋ถ„

์—”ํ‹ฐํ‹ฐ์˜ ์†์„ฑ์€ ๋Œ€์†Œ๋ฌธ์ž๋ฅผ ๊ตฌ๋ถ„ -> Member, username์€ ๋Œ€์†Œ๋ฌธ์ž๋ฅผ ๊ตฌ๋ถ„ํ•˜๊ณ  select, from as ์™€ ๊ฐ™์€ JPQL ์šฉ์–ด๋Š” ๋Œ€์†Œ๋ฌธ์ž๋ฅผ ๊ตฌ๋ถ„ํ•˜์ง€ ์•Š์Œ

์—”ํ‹ฐํ‹ฐ ์ด๋ฆ„

JPQL์—์„œ ์‚ฌ์šฉํ•œ Member๋Š” ํด๋ž˜์Šค ๋ช…์ด ์•„๋‹ˆ๋ผ ์—”ํ‹ฐํ‹ฐ ๋ช…์ด๋‹ค. ์—”ํ‹ฐํ‹ฐ ๋ช…์„ ๋”ฐ๋กœ ์ง€์ •ํ•˜์ง€ ์•Š๋Š” ์ด์ƒ์€ ํด๋ž˜์Šค๋ช…์„ ๊ธฐ๋ณธ์ ์œผ๋กœ ์—”ํ‹ฐํ‹ฐ๋ช…์œผ๋กœ ์ฒ˜๋ฆฌ ๊ทธ๋ž˜์„œ ๊ธฐ๋ณธ๊ฐ’์ธ ํด๋ž˜์Šค ๋ช…์„ ์—”ํ‹ฐํ‹ฐ ๋ช…์œผ๋กœ ์‚ฌ์šฉํ•˜๋Š” ๊ฒƒ์„ ์ถ”์ฒœ

๋ณ„์นญ์€ ํ•„์ˆ˜

๊ตณ์ด as์„ ์‚ฌ์šฉํ•ด์„œ ๋ณ„์นญ์„ ์‚ฌ์šฉํ•œ ๊ฒƒ์œผ๋กœ ๋ณด์ด๋Š”๋ฐ, JPQL์€ ๋ณ„์นญ์„ ํ•„์ˆ˜๋กœ ์‚ฌ์šฉํ•ด์ฃผ์–ด์•ผ ํ•œ๋‹ค.

TypeQuery, Query

์ž‘์„ฑํ•œ JPQL์„ ์‹คํ–‰ํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š” ์ฟผ๋ฆฌ ๊ฐ์ฒด๋ฅผ ๋งŒ๋“ค์–ด์•ผ ํ•œ๋‹ค. ์ฟผ๋ฆฌ ๊ฐ์ฒด๋กœ ์กด์žฌํ•˜๋Š” ๊ฒƒ์ด TypeQuery, Query์ด๋ ‡๊ฒŒ ์กด์žฌํ•˜๋Š”๋ฐ ์ฐจ์ด์ ์œผ๋กœ๋Š” ๋ฐ˜ํ™˜ํ•  ํƒ€์ž…์ด ์žˆ๋‹ค๋ฉด TypeQuery, ๋ฐ˜ํ™˜ํ•  ํƒ€์ž…์„ ์ง€์ •ํ•  ์ˆ˜ ์—†๋‹ค๋ฉด Query ์ด๋ ‡๊ฒŒ ๋‚˜๋ˆ„์–ด ์ง„๋‹ค TypeQuery, Query ์‚ฌ์šฉ๊ธฐ

TypedQuery<Member> query = em.createQuery("SELECT m FROM Member m", Member.class);

List<Member> resultList = query.getResultList();
for(Member member : resultList){
    System.out.println("member = "+member);
}

---------------------------------------------------------------------------------------------------------

Query query = em.createQuery("SELECT m.username, m.age from Member m");
List resultList = query.getResultList();

for(Object o : resultList){
    Object[] result = (Object[]) o;
    System.out.println("username = " + result[0]);
    System.out.println("age = " + result[1]);
}

์ฒซ ๋ฒˆ์งธ๋Š” ๋ฆฌํ„ด๋  ํƒ€์ž…์„ ๋ฏธ๋ฆฌ ์•Œ๊ณ  ์žˆ์—ˆ๊ธฐ ๋•Œ๋ฌธ์— ์กฐํšŒํ•œ ์ฟผ๋ฆฌ๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๊ฒƒ๋„ ์–ด๋ ต์ง€ ์•Š๊ฒŒ ์‚ฌ์šฉํ•˜๋Š” ๋ฐ˜๋ฉด ๋‘ ๋ฒˆ์งธ๋Š” ๋ฐ˜ํ™˜ํ•  ํƒ€์ž…์ด ์• ๋งคํ•˜๋‹ค ๋ณด๋‹ˆ๊นŒ ์กฐ์ฃ„ํ•˜๋Š” ๊ฒƒ๋„ ์–ด๋ ต๊ฒŒ ์กฐํšŒํ•˜๋Š” ๋ชจ์Šต์ด๋‹ค... ๊ทธ๋ž˜ ๊ตณ์ด ์ฐพ์•„์„œ ๋˜ ํƒ€์ž… ๋ณ€ํ™˜ํ•˜๊ณ  ์žˆ์ง€ ๋ง๊ณ  ๊ทธ๋ƒฅ ์• ์ดˆ๋ถ€ํ„ฐ ์ •ํ•ด์ง„ ํƒ‘์œผ๋กœ ๋นผ๋ฒ„๋ฆฌ์ž.... ๊ฒฐ๊ณผ๋ฅผ ์กฐํšŒํ•˜๋Š” ๋ฐฉ๋ฒ•์œผ๋กœ๋Š”

  1. query.getResultList() : ๊ฒฐ๊ณผ๋ฅผ ์˜ˆ์ œ๋กœ ๋ฐ˜ํ™˜ํ•˜๊ณ  ๋งŒ์•ฝ์— ๊ฒฐ๊ณผ๊ฐ€ ์—†์œผ๋ฉด ๋นˆ ์ปฌ๋ ‰์…˜์„ ๋ฐ˜ํ™˜

  2. query.getSingleResult() : ๊ฒฐ๊ณผ๊ฐ€ ์ •ํ™•ํžˆ ํ•˜๋‚˜์ผ ๋•Œ ์‚ฌ์šฉํ•จ - ๊ฒฐ๊ณผ๊ฐ€ ์—†๋Š” ๊ฒฝ์šฐ์—๋Š” NoResultException์„ ๋˜์ง€๊ณ  ๊ฒฐ๊ณผ๊ฐ€ ํ•˜๋‚˜๋ณด๋‹ค ๋งŽ์œผ๋ฉด NonUniqueResultException์„ ๋˜์ง

ํŒŒ๋ผ๋ฏธํ„ฐ ๋ฐ”์ธ๋”ฉ

JDBC์—์„œ๋Š” ์œ„์น˜ ๊ธฐ์ค€ ํŒŒ๋ผ๋ฏธํ„ฐ ๋ฐ”์ธ๋”ฉ๋งŒ์„ ์ง€์›ํ•˜๊ณ  ์žˆ์ง€๋งŒ JPQL์€ ์ด๋ฆ„ ๊ธฐ์ค€ ํŒŒ๋ผ๋ฏธํ„ฐ ๋ฐ”์ธ๋”ฉ๋„ ์ง€์›ํ•จ

์ด๋ฆ„ ๊ธฐ์ค€ ํŒŒ๋ผ๋ฏธํ„ฐ

ํŒŒ๋ผ๋ฏธํ„ฐ๋ฅผ ์ด๋ฆ„์„ ๊ธฐ์ค€์œผ๋กœ ๊ตฌ๋ถ„ํ•˜๋Š” ๋ฐฉ๋ฒ•์ด๊ณ , ์ด๋ฆ„ ๊ธฐ์ค€ ํŒŒ๋ผ๋ฏธํ„ฐ ์•ž์—๋Š” :์„ ์‚ฌ์šฉํ•œ๋‹ค

String usernameParam = "User1";
TypedQuery<Member> query = em.createQuery("SELCT m FROM Member m WHERE m.username = :username",
Member.class);

query.setParameter("username", usernameParam);
List<Member> resultList = query.getResultList();

:username ์ด๋ ‡๊ฒŒ ์‚ฌ์šฉํ•ด์ฃผ๊ณ , query.setParameter(์ด๋ฆ„, ๊ฐ’) ์ด๋ ‡๊ฒŒ ํŒŒ๋ผ๋ฏธํ„ฐ์— ๊ฐ’์„ ๋ฐ”์ธ๋”ฉํ•ด์ฃผ์ž

์œ„์น˜ ๊ธฐ์ค€ ํŒŒ๋ผ๋ฏธํ„ฐ

List<Member> members = em.createQuery("select m from Member m where m.username = ?1", Member.class)
      .setParameter(1, usernameParam)
      .getResultList();

์œ„์น˜ ๊ธฐ๋ฐ˜ ํŒŒ๋ผ๋ฏธํ„ฐ๋Š” ?(๋ฌผ์Œํ‘œ) ๋‹ค์Œ์— ์œ„์น˜ ๊ฐ’์„ ์ฃผ๋Š” ๊ฑธ๋กœ ์‹œ์ž‘ํ•œ๋‹ค ๊ทธ๋ฆฌ๊ณ  query.setParameter(์œ„์น˜, ๊ฐ’) ์œผ๋กœ ๊ฐ’์„ ๋ฐ”์ธ๋”ฉํ•ด์คŒ

ํ”„๋กœ์ ์…˜

ํ”„๋กœ์ ์…˜์ด๋ž€? select ์ ˆ์— ์กฐํšŒํ•  ๋Œ€์ƒ์„ ์ง€์ •ํ•˜๋Š” ๊ฒƒ์„ ์˜๋ฏธํ•จ SELECT ํ”„๋กœ์ ์…˜๋Œ€์ƒ FROM ์ด๋ ‡๊ฒŒ ๋Œ€์ƒ์„ ์ง€์ •ํ•˜๋Š”๋ฐ ํƒ€์ž…์œผ๋กœ๋Š” ๋‹ค์–‘ํ•˜๊ฒŒ ์žˆ๋‹ค

์—”ํ‹ฐํ‹ฐ ํ”„๋กœ์ ์…˜

SELECT m FROM Member m
SELECT m.team FROM Member m

์œ„ ์ฟผ๋ฆฌ๋ฌธ 2๊ฐœ ๋‹ค ์—”ํ‹ฐํ‹ฐ๋ฅผ ํ”„๋กœ์ ์…˜์˜ ๋Œ€์ƒ์œผ๋กœ ์ •ํ•ด์„œ ๊ฐ์ฒด๋ฅผ ๋ฐ”๋กœ ์กฐํšŒํ–ˆ๋‹ค ์ด๊ฑด ํ•˜๋‚˜ํ•˜๋‚˜ ์กฐํšŒํ•˜๋Š” SQL๊ณผ๋Š” ์ฐจ์ด๊ฐ€ ์žˆ์Œ ์ด๋ ‡๊ฒŒ ์กฐํšŒํ•œ ์—”ํ‹ฐํ‹ฐ๋Š” ์˜์†์„ฑ ์ปจํ…์ŠคํŠธ์—์„œ ๊ด€๋ฆฌ๋จ

์ž„๋ฒ ๋””๋“œ ํƒ€์ž… ํ”„๋กœ์ ์…˜

์—”ํ‹ฐํ‹ฐ์™€ ๋น„์Šทํ•˜์ง€๋งŒ ์—ญ์‹œ ์ž„๋ฒ ๋””๋“œ ํƒ€์ž…์ด๊ธฐ ๋•Œ๋ฌธ์— ์กฐํšŒ์˜ ์‹œ์ž‘์ ์ด ๋  ์ˆ˜ ์—†๋‹ค๋Š” ์ œ์•ฝ์ด ์กด์žฌํ•œ๋‹ค.

String query = "select o.address from Order o";
List<Address> addresses = em.createQuery(query, Address.class).getResultList();

์ž„๋ฒ ๋””๋“œ ํƒ€์ž…์€ ์—”ํ‹ฐํ‹ฐ ํƒ€์ž…์ด ์•„๋‹Œ ๊ฐ’ ํƒ€์ž…์ด๋‹ค. ๋”ฐ๋ผ์„œ ์ด๋ ‡๊ฒŒ ์ง์ ‘ ์กฐํšŒํ•œ ์ž„๋ฒ ๋””๋“œ ํƒ€์ž…์€ ์˜์†์„ฑ ์ปจํ…์ŠคํŠธ์—์„œ ๊ด€๋ฆฌ๋˜์ง€ ์•Š๋Š”๋‹ค

์Šค์นผ๋ผ ํƒ€์ž… ํ”„๋กœ์ ์…˜

์ˆซ์ž, ๋ฌธ์ž, ๋‚ ์งœ์™€ ๊ฐ™์€ ๊ธฐ๋ณธ ๋ฐ์ดํ„ฐ ํƒ€์ž…๋“ค์„ ์Šค์นผ๋ผ ํƒ€์ž…์ด๋ผ๊ณ  ์ •์˜ํ•œ๋‹ค. ์˜ˆ๋กœ ์ „์ฒด ํšŒ์›์˜ ์ด๋ฆ„์„ ์กฐํšŒํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š”

List<String> query = em.createQuery("SELECT username FROM Member", String.class).getResultList();

์—ฌ๋Ÿฌ ๊ฐ’ ์กฐํšŒ

๋งŒ์•ฝ์— ํ”„๋กœ์ ์…˜์—์„œ ์—ฌ๋Ÿฌ ๊ฐ’๋“ค์„ ์„ ํƒํ•˜๊ฒŒ ๋˜๋Š” ์ˆœ๊ฐ„, ์œ„์—์„œ ์‚ฌ์šฉํ–ˆ๋˜ TypeQuery๋Š” ์‚ฌ์šฉํ•  ์ˆ˜ ์—†๊ณ  ๋‹จ์ˆœํ•œ Query๋ฅผ ์‚ฌ์šฉํ•ด์•ผ ํ•œ๋‹ค. ์˜ˆ์ œ๋กœ ํ™•์ธ

Query query = em.createQuery("SELECT m.username, m.age FROM Member m");
List resultList = query.getResultList();

Iterator iterator = resultList.iterator();
while(iterator.hasNext()){
    Object[] row = (Object[]) iterator.next();
    String username = (String) row[0];
    Integer age = (Integer) row[1];
}

์ด๋ ‡๊ฒŒ ๋ฟ๋งŒ ์•„๋‹ˆ๋ผ ์—”ํ‹ฐํ‹ฐ ํƒ€์ž…๋„ ์—ฌ๋Ÿฌ ๊ฐ’์„ ํ•จ๊ป˜ ์กฐํšŒํ•  ์ˆ˜ ์žˆ์Œ

List<Object[]> resultList =
    em.createQuery("SELECT o.member, o.product, o.orderAmount FROM Order o").getResultList();

for(Object[] row : resultList){
  Member member = (Member) row[0];
  Product product = (Product) row[1];
  int orderAmount = (Integer) row[2];
}

NEW ๋ช…๋ น์–ด ์œ„์˜ ๊ฒฝ์šฐ์—๋Š” ๋ชจ๋“  result๋ฅผ ๋ฐ›์•„์ฃผ๋Š” ๊ฐ์ฒด๊ฐ€ ์กด์žฌํ•˜์ง€ ์•Š์•˜๊ธฐ ๋•Œ๋ฌธ์— ์ €๋ ‡๊ฒŒ Object[]์œผ๋กœ ๋ฆฌํ„ด๋ฐ›์•„์„œ ๊ฐ๊ฐ ๋งคํ•‘ํ•ด์ฃผ๋Š” ๊ณผ์ •์„ ๊ฑฐ์ณค๋Š”๋ฐ, ์ด๋Ÿฌํ•œ ๋ฐฉ๋ฒ•์„ DTO๋ฅผ ์ƒ์„ฑํ•จ์œผ๋กœ์จ ์˜๋ฏธ ์žˆ๋Š” ๊ฐ์ฒด๋กœ ๋งŒ๋“ค์–ด์„œ ๋ฐ›์„ ์ˆ˜ ์žˆ๋‹ค..! ๋Œ€์‹  DTO๋ฅผ ์ƒ์„ฑํ•˜๋Š”๋ฐ ์žˆ์–ด์„œ -> AllArgsConstructer๋Š” ํ•„์ˆ˜๋กœ ํ•„์š”ํ•˜๋‹ค๋Š”์ 

TypeQuery<UserDTO> query = em.createQuery("SELCT new jpabook.jpql.UserDTO(m.username, m.age) FROM Member m", UserDTO.class);
List<UserDTO> resultList = query.getResultList();

new ํ‚ค์›Œ๋“œ๋ฅผ ์‚ฌ์šฉํ•ด์„œ ์ •--๋ง ๊ท€์ฐฎ์€ ๊ฐ์ฒด๋ณ€ํ™˜ ์ž‘์—…์„ ์†์‰ฝ๊ฒŒ ์ฒ˜๋ฆฌํ•  ์ˆ˜ ์žˆ๋‹ค๋Š” ์ ์ด ์ข‹๋„ค์š”! ๊ทธ๋ž˜๋„ ์ฃผ์˜ํ•  ์  2๊ฐ€์ง€

  1. ํŒจํ‚ค์ง€ ๋ช…์„ ํฌํ•จํ•œ ์ „์ฒด ํด๋ž˜์Šค ๋ช…์„ ์ž…๋ ฅํ•ด์•ผ ํ•œ๋‹ค๋Š” ์ !

  2. ์ˆœ์„œ์™€ ํƒ€์ž…์ด ์ผ์น˜ํ•˜๋Š” ์ƒ์„ฑ์ž๊ฐ€ ํ•„์š”ํ•˜๋‹ค๋Š” ์ !

ํŽ˜์ด์ง• API

ํŽ˜์ด์ง• ์ฒ˜๋ฆฌ์šฉ SQL์„ ์ž‘์„ฑํ•˜๋Š” ์ผ์€ ์ •๋ง ๋งค์šฐ ์ง€๋ฃจํ•œ ์ ์ด๋‹ค. ๊ทธ๋ฆฌ๊ณ  ๊ฐ€์žฅ ํฐ ๋ฌธ์ œ๋Š” ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค๋งˆ๋‹ค ํŽ˜์ด์ง• ์ฒ˜๋ฆฌํ•˜๋Š” ์ฟผ๋ฆฌ๊ฐ€ ๋‹ค๋ฅด๋‹ค๋Š” ์  ๊ทธ๋ž˜์„œ JPA์—์„œ๋Š” 2๊ฐœ์˜ API๋กœ ์ถ”์ƒํ™” ํ•ด๋‘์—ˆ๋‹ค

  • setFirstResult(int startPosition) : ์กฐํšŒ ์‹œ์ž‘ ์œ„์น˜

  • setMaxResult(int maxResult) : ์กฐํšŒํ•  ๋ฐ์ดํ„ฐ ์ˆ˜

TypeQuery<Member> query = em.createQuery("SELECT m FROM Member m ORDER BY m.username DESC", Member.class);
query.setFirstResult(10);
query.setMaxResult(20);
query.getResultList();

์œ„์˜ ์ฝ”๋“œ๋Š” 10์ด ์‹œ์ž‘์ด๊ธฐ ๋•Œ๋ฌธ์— 11๋ถ€ํ„ฐ 20๊ฐœ๋ฅผ ์กฐํšŒํ•œ๋‹ค. ์ฆ‰ 11 ~ 30๋ฒˆ์˜ ๋ฐ์ดํ„ฐ๋ฅผ ์กฐํšŒํ•œ๋‹ค. ๋งŒ์•ฝ ๋” ์ถ”๊ฐ€์ ์œผ๋กœ ํŽ˜์ด์ง• API๋ฅผ ์ตœ์ ํ™”์‹œํ‚ค๊ณ  ์‹ถ๋‹ค๋ฉด ๋„ค์ดํ‹ฐ๋ธŒ๋กœ ๋‹ค์‹œ ์ฟผ๋ฆฌ๋ฅผ ์งœ์•ผํ•œ๋‹ค๋Š” ์ ์„ ๊ธฐ์–ตํ•˜๊ณ  ์žˆ์ž...!

์ง‘ํ•ฉ๊ณผ ์ •๋ ฌ

์ง‘ํ•ฉ์€ ์ง‘ํ•ฉํ•จ์ˆ˜์™€ ํ•จ๊ป˜ ํ†ต๊ณ„ ์ •๋ณด๋ฅผ ๊ตฌํ•  ๋•Œ ์‚ฌ์šฉํ•จ

์ง‘ํ•ฉ ํ•จ์ˆ˜

  • COUNT : ๊ฒฐ๊ณผ ์ˆ˜๋ฅผ ๊ตฌํ•œ๋‹ค -> ๋ฐ˜ํ™˜ ๊ฐ’ Long

  • MAX, MIN : ์ตœ๋Œ€, ์ตœ์†Œ ๊ฐ’์„ ๊ตฌํ•œ๋‹ค -> ๋ฌธ์ž, ์ˆซ์ž, ๋‚ ์งœ ๋“ฑ์— ์‚ฌ์šฉ

  • AVG : ํ‰๊ท ๊ฐ’์„ ๊ตฌํ•˜๊ณ  ์ˆซ์ž ํƒ€์ž…์—๋งŒ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Œ -> ๋ฐ˜ํ™˜ ๊ฐ’ double

  • SUM : ํ•ฉ์„ ๊ตฌํ•˜๊ณ  ์ˆซ์ž ํƒ€์ž…์—๋งŒ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Œ -> ๊ฐ ๋”ํ•œ ํƒ€์ž…์— ๋งž๋Š” ๋ฐ˜ํ™˜ ๊ฐ’์„ ๋ฐ˜ํ™˜ํ•จ

์ฃผ์˜ํ• ์ 

  • null ๊ฐ’์€ ๋ฌด์‹œ๋˜๊ณ  ์ง‘๊ณ„๋จ

  • ๊ฐ’์ด ์—†๋Š”๋ฐ min, max, avg, sum์„ ๋•Œ๋ฆฌ๋ฉด null์ด ๋˜์ง€๋งŒ count๋Š” 0์ด ๋จ

  • distinct๋Š” ์ค‘๋ณต๋œ ๊ฐ’์„ ์ œ๊ฑฐํ•˜๊ณ  ๋‚˜์„œ ์ถœ๋ ฅ๋จ

  • distinct๋Š” count๋ฅผ ์‚ฌ์šฉํ•  ๋•Œ ์ž„๋ฒ ๋””๋“œ ํƒ€์ž…์„ ์ง€์›ํ•˜์ง€ ์•Š์Œ

GROUP BY, HAVING

GROUP BY ๋Š” ํ†ต๊ณ„ ๋ฐ์ดํ„ฐ๋ฅผ ๊ตฌํ•  ๋•Œ ํŠน์ • ๊ทธ๋ฃน๋ผ๋ฆฌ ๋ฌถ๋Š” ์˜ˆ์•ฝ์–ด์ด๋‹ค. HAVING์€ GROUP BY์™€ ํ•จ๊ป˜ ์‚ฌ์šฉํ•˜๋Š”๋ฐ GROUP BY๋กœ ๊ทธ๋ฃนํ™”ํ•œ ํ†ต๊ณ„ ๋ฐ์ดํ„ฐ๋ฅผ ๊ธฐ์ค€์œผ๋กœ ํ•„ํ„ฐ๋ง ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ๋ฒ•์€ ์ด๋Ÿฌํ•˜๋‹ค

groupby_์ ˆ :: = GROUP BY {๋‹จ์ผ๊ฐ’ ๊ฒฝ๋กœ | ๋ณ„์นญ }+
having_์ ˆ :: = HAVING ์กฐ๊ฑด์‹

์ด๋Ÿฌํ•œ ์ฟผ๋ฆฌ๋“ค์€ ๋ณดํ†ต ํ†ต๊ณ„(reporting)์ฟผ๋ฆฌ๋ผ๊ณ  ํ•œ๋‹ค ์•„์ฃผ ์œ ์šฉํ•˜๋‹ค๊ณ  ๋ณผ ์ˆ˜ ์žˆ์ง€๋งŒ ์ด๋ฏธ ์กด์žฌํ•˜๋Š” ๋ฐ์ดํ„ฐ๋ฅผ ๊ธฐ์ค€์œผ๋กœ ์ฒ˜๋ฆฌํ•˜๋Š” ์ฟผ๋ฆฌ์ด๊ธฐ ๋•Œ๋ฌธ์— ์‹ค์‹œ๊ฐ„์œผ๋กœ ์‚ฌ์šฉํ•˜๊ธฐ์—” ์–ด๋ ค์›€ ์•„์ฃผ ๋งŽ์€ ๋ฐ์ดํ„ฐ๋“ค์„ ํ†ต๊ณ„์ฒ˜๋ฆฌ ํ•˜๊ธฐ์—๋Š” ํ†ต๊ณ„ ๊ฒฐ๊ณผ๋งŒ ์ €์žฅํ•˜๋Š” ํ…Œ์ด๋ธ”์„ ๋ณ„๋„๋กœ ๋งŒ๋“ค์–ด ๋‘๊ณ  ์‚ฌ์šฉ์ž๊ฐ€ ์ ์€ ์ƒˆ๋ฒฝ์— ๋Œ๋ ค์„œ ๊ฒฐ๊ณผ๋ฅผ ์ €์žฅํ•˜๋Š” ๋ฐฉ์•ˆ์ด ๋ฒ ์ŠคํŠธ #### ORDER BY ORDER BY๋Š” ๊ฒฐ๊ณผ๋ฅผ ๋‚ด๋ฆผ์ฐจ์ˆœ์ด๋‚˜, ์˜ค๋ฆ„์ฐจ์ˆœ์œผ๋กœ ์ •๋ฆฌํ•ด์ฃผ๋Š” ๋ฐฉ๋ฒ• ```java orderby_์ ˆ ::= ORDER BY {์ƒํƒœํ•„๋“œ ๊ฒฝ๋กœ | ๊ฒฐ๊ณผ ๋ณ€์ˆ˜ [ASC | DESC]}+ ``` ASC : ์˜ค๋ฆ„์ฐจ์ˆœ(๊ธฐ๋ณธ๊ฐ’ - ๋”ฐ๋กœ ์„ค์ •์•ˆํ•ด๋„ ์•Œ์•„์„œ ์˜ค๋ฆ„์ฐจ์ˆœ) DESC : ๋‚ด๋ฆผ์ฐจ์ˆœ

Previous๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ ์–ธ์–ดNextJPQL part2

Last updated 3 years ago

Was this helpful?