๐Ÿฅ•
TIL
  • [TIL] Studying tech / computer science knowledge
  • KeyMap
  • ์•Œ๊ณ ๋ฆฌ์ฆ˜
    • ๋ณต์žก๋„ ๊ณ„์‚ฐ ( Computational Complexity )
    • DisjointSet-unionFind
    • Bellman-ford Algorithm
    • Dijkstra's Algorithm
    • DP ( Dynamic Programming , ๋™์  ๊ณ„ํš๋ฒ• )
    • ํ”Œ๋กœ์ด๋“œ-์›Œ์…œ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (Floyd-Warshall algorithm)
    • Kruskal's Algorithm
    • ์ตœ์žฅ ์ฆ๊ฐ€ ์ˆ˜์—ด (Longes Increasing Subsequence)
    • Prim's Algorithm
    • ์ •๋ ฌ
    • ์‹œ๊ฐ„๋ณต์žก๋„ ์™€ ๊ณต๊ฐ„๋ณต์žก๋„ ( Time Complexity & Space Complexity )
    • Topological Sort (์œ„์ƒ ์ •๋ ฌ)
  • ์ฑ… ์ฝ๊ณ ๋‚œ ํ›„ ์š”์•ฝ
    • ํ”„๋กœ๊ทธ๋ž˜๋ฐ ๋Œ€ํšŒ์—์„œ ๋ฐฐ์šฐ๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋ฌธ์ œํ•ด๊ฒฐ ์ „๋žต
    • cleancode
    • ๋„๋ฉ”์ธ ์ฃผ๋„ ์„ค๊ณ„๋กœ ์‹œ์ž‘ํ•˜๋Š” ๋งˆ์ดํฌ๋กœ์„œ๋น„์Šค ๊ฐœ๋ฐœ
    • ์˜ค๋ธŒ์ ํŠธ
  • CDC
    • debzium
    • kafka
  • ๊ฐœ๋ฐœ ์ƒ์‹
    • asciidoctor
    • ์ปดํŒŒ์ผ๋Ÿฌ
    • ELK ์Šคํƒ
    • ์—”๋””์•ˆ
    • git
    • Gitmoji
    • ํ…Œ์ŠคํŠธ ์ข…๋ฅ˜
    • ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์™€ ํ”„๋ ˆ์ž„์›Œํฌ
    • ์ •๊ทœ ํ‘œํ˜„์‹
    • REST API
    • ๋™๊ธฐ์™€ ๋น„๋™๊ธฐ / Blocking๊ณผ NonBlocking
    • Transaction Script์™€ Domain Model
    • ๋””์ž์ธ ํŒจํ„ด
      • ํ–‰๋™ ํŒจํ„ด
      • ๊ฐ์ฒด ์ƒ์„ฑ ํŒจํ„ด
        • ์ถ”์ƒ ํŒฉํ† ๋ฆฌ ํŒจํ„ด
        • ๋นŒ๋” ํŒจํ„ด
        • ํŒฉํ† ๋ฆฌ ๋ฉ”์„œ๋“œ ํŒจํ„ด
        • [์ƒ์„ฑ ํŒจํ„ด] ํ”„๋กœํ†  ํƒ€์ž… (Prototype Parttern)
        • ์‹ฑ๊ธ€ํ†ค
      • ๊ตฌ์กฐ ํŒจํ„ด
        • ์–ด๋Œ‘ํ„ฐ ํŒจํ„ด
        • ๋ธŒ๋ฆฟ์ง€ ํŒจํ„ด
        • ์ปดํฌ์ง“(Composite) ํŒจํ„ด
        • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ
        • ํ”„๋ก์‹œ
    • refactoring
      • ์ค‘๋ณต ์ฝ”๋“œ
      • ์ „์—ญ ๋ฐ์ดํ„ฐ
      • ๊ธด ํ•จ์ˆ˜
      • ๊ธด ๋งค๊ฐœ๋ณ€์ˆ˜ ๋ชฉ๋ก
      • ๊ฐ€๋ณ€ ๋ฐ์ดํ„ฐ
      • ์ดํ•ดํ•˜๊ธฐ ํž˜๋“  ์ด๋ฆ„
  • ์ž๋ฃŒ๊ตฌ์กฐ
    • AVL Tree
    • Splay Tree
    • aaTree
    • array-list
    • ์ž๋ฃŒ๊ตฌ์กฐ ์‹œ๊ฐ„/๊ณต๊ฐ„ ๋ณต์žก๋„
    • ๊ทธ๋ž˜ํ”„
    • ํž™
    • Red Black Tree
    • stack-queue
    • ํŠธ๋ฆฌ ( Tree )
  • DevOps
    • MSA
    • Kubernetes
      • AccessingAPI
      • controller
      • dashboard
      • kubernetes
      • object
      • pod
      • service
      • volume
  • Java
    • ์–ด๋…ธํ…Œ์ด์…˜
    • ์ œ์–ด๋ฌธ
    • ๋ฐ์ดํ„ฐ ํƒ€์ž…
    • Enum
    • jvm
    • ์—ฐ์‚ฐ์ž
    • thread
    • Java8
      • CompletableFuture
      • Date/Time
      • ์–ด๋…ธํ…Œ์ด์…˜๊ณผ ๋ฉ”ํƒ€์ŠคํŽ˜์ด์Šค
      • ์ธํ„ฐํŽ˜์ด์Šค
      • ๋žŒ๋‹ค์‹
      • Optional
      • ์ŠคํŠธ๋ฆผ
  • JavaScript
    • moduleProject
    • webpack-babel
    • ์ฝ”์–ด ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      • array
      • ํ•จ์ˆ˜ ๋ฐ”์ธ๋”ฉ
      • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ์™€ ํฌ์›Œ๋”ฉ
      • Class
      • ๋น„๊ต ์—ฐ์‚ฐ์ž
      • Date ๋‚ด์žฅ ๊ฐ์ฒด
      • destructuring-assignment
      • function
      • ํ•จ์ˆ˜์˜ prototype ํ”„๋กœํผํ‹ฐ
      • ๊ฐ€๋น„์ง€ ์ปฌ๋ ‰์…˜ ( Garbage Collection )
      • JSON (JavaScript Object Notation)
      • map-set
      • ๋‚ด์žฅ ํ”„๋กœํ† ํƒ€์ž…
      • new์—ฐ์‚ฐ์ž์™€ ์ƒ์„ฑ์ž ํ•จ์ˆ˜
      • ๊ฐ์ฒด
      • Object.keys, values, entries
      • ์˜ต์…”๋„ ์ฒด์ด๋‹ '?.'
      • ํ”„๋กœํผํ‹ฐ ํ”Œ๋ž˜๊ทธ
      • ํ”„๋กœํผํ‹ฐ ์ข…๋ฅ˜
      • ํ”„๋กœํ†  ํƒ€์ž…
      • ํ˜ธ์ถœ ์Šค์ผ€์ค„๋ง ( scheduling a call )
      • scope
      • this
      • type-conversions
      • type
      • ํ•จ์ˆ˜์˜ ์ž๋ฃŒํ˜•
      • var_let_const
  • Linux
    • ๊ธฐ๋ณธ ๋ช…๋ น์–ด
    • ํŒŒ์ผ ์ข…๋ฅ˜
    • ๋ฆฌ๋ˆ…์Šค
  • ๋„คํŠธ์›Œํฌ
    • ์‘์šฉ ๊ณ„์ธต ( Application Layer )
    • ์˜ค๋ฅ˜ ๊ฒ€์ถœ๊ณผ ์˜ค๋ฅ˜ ์ •์ •
    • Http
    • Http Header
    • ์ปดํ“จํ„ฐ ๋„คํŠธ์›Œํฌ๋ž€
    • ๋„คํŠธ์›Œํฌ ๊ณ„์ธต
    • ๋„คํŠธ์›Œํฌ ์ œ์–ด ์˜์—ญ
    • ์ „์†ก ๊ณ„์ธต ( Transport Layer )
  • PHP
    • Facade
    • composer
    • scopeResolutionOperator
    • Laravel
      • SocialProvider
      • architecture
      • blade
      • controller
      • db
      • dbArchitecture
      • debug
      • eloquent
      • email
      • event
      • exceptionHandling
      • middleware
      • model
      • modelFactory
      • pagingLoading
      • queryBuilder
      • route
      • scout
      • seeding
      • tntsearch
      • validate
      • view
  • React
    • Next.js
    • React ๋ž€?
  • Spring
    • Controller
    • ์š”์ฒญ์ด ๋“ค์–ด์™”์„๋•Œ ์Šคํ”„๋ง์ด ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐฉ๋ฒ• ( ๋‚ด๋ถ€๊ตฌ์กฐ )
    • ConfigurationProperties
    • Entity / DTO / VO
    • Maven
    • Repository์™€ DAO
    • ์Šคํ”„๋ง ๋นˆ
    • Spring Framework
    • MVC ํŒจํ„ด
    • ๋„๋ฉ”์ธ ์ž…๋ ฅ๊ฐ’ ๊ฒ€์ฆ
    • Spring Cloud
      • Spring Cloud
      • Eureka
    • Spring Data
      • JPA
      • JPA ์–ด๋…ธํ…Œ์ด์…˜
      • ์—”ํ‹ฐํ‹ฐ ๋น„๊ต
      • ๋ณตํ•ฉ ํ‚ค์™€ ์‹๋ณ„ ๊ด€๊ณ„ ๋งคํ•‘
      • JPA ์˜ˆ์™ธ์ฒ˜๋ฆฌ
      • ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ
      • EntityManagerFactory์™€ EntityManager
      • JPA ์ตœ์ ํ™”
      • ํ”„๋ก์‹œ์™€ ์—ฐ๊ด€๊ด€๊ณ„ ๋งตํ•‘
      • ์—ฐ๊ด€๊ด€๊ณ„
      • ์ƒ์†๊ด€๊ณ„ ๋งตํ•‘
      • ํŠธ๋žœ์žญ์…˜ ๋ฒ”์œ„์™€ ์˜์†์„ฑ ์ปจํ…์ŠคํŠธ
      • ๋ฐ์ดํ„ฐ ํƒ€์ž…
      • MySQL ์—ฐ๊ฒฐ
      • Pageable
    • Spring Project๋“ค๊ณผ library
      • Custom Serialize
      • Elasticsearch Index API
      • Spring HATEOAS
      • lombok (๋กฌ๋ณต)
      • Model Mapper
      • Object Mapper
      • Representation Model
      • Spring REST Docs
      • Spring Boot
    • Spring Security
      • Spring Security
      • Authentication
      • Authentication Filter
      • Authorization Filter
      • Filter Chain
      • SecurityContext
      • Spring OAuth2.0
    • Spring Test
      • AssertJ
      • Junit5
      • JunitParams
      • Mock Object
  • DataBase
    • ALIAS
    • CONCAT
    • CTE
    • Group By
    • HAVING
    • IFNULL
    • ์ธ๋ฑ์Šค
    • JOIN
    • ORDER BY
    • ROLLUP
    • SELECT
    • SELECT DISTINCT
    • SQL
    • WHERE
  • Web ์ƒ์‹
    • OAuth
    • WAS
    • HTTPํ†ต์‹  ๊ธฐ๋ฐ˜ ์ธ์ฆ
    • ๋ธŒ๋ผ์šฐ์ €
    • CSR ๊ณผ SSR
    • HTTPS
    • Web
Powered by GitBook
On this page
  • Hibernate
  • Spring Data JPA
  • ๋™์ž‘๊ณผ์ •
  • ์ €์žฅ/์กฐํšŒ ๊ณผ์ •
  • ์žฅ์ 
  • ์‚ฌ์šฉ๋ฒ•
  • JPA NamedQuery
  • @Query
  • @Modifying
  • Reference
  1. Spring
  2. Spring Data

JPA

Java Persistence API์•ฝ์ž๋กœ ๊ฐ์ฒด์™€ RDB๊ฐ„์— ๋งตํ•‘ ์‹œ์ผœ์ฃผ๋Š” ์ธํ„ฐํŽ˜์ด์Šค์˜ ๋ชจ์Œ์ด๋‹ค. ์ฆ‰, ํŠน์ •๊ธฐ๋Šฅ์„ ์ˆ˜ํ–‰ํ•˜๋Š” ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๊ฐ€ ์•„๋‹ˆ๋ผ ๋ช…์„ธ์ด๋‹ค.

Hibernate

JPA์˜ ๊ตฌํ˜„์ฒด๋กœ, ์ธํ„ฐํŽ˜์ด์Šค์ธ JPA๋ฅผ ๊ตฌํ˜„ํ•œ class๊ฐ™์€ ๊ฒƒ.

JPA๋ฅผ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด ๋ฐ˜๋“œ์‹œ Hibernate๋ฅผ ์‚ฌ์šฉํ•  ํ•„์š”๊ฐ€ ์—†๊ณ  ๋‹ค๋ฅธ JPA๊ตฌํ˜„์ฒด๋ฅผ ์‚ฌ์šฉํ•ด๋„ ๋˜๋ฉฐ, ์ง์ ‘ JPA๋ฅผ ๊ตฌํ˜„ํ–์„œ ์‚ฌ์šฉํ•  ์ˆ˜๋„ ์žˆ๋‹ค.

Spring Data JPA

Spring์—์„œ ์ œ๊ณตํ•˜๋Š” ๋ชจ๋“ˆ ์ค‘ ํ•˜๋‚˜๋กœ ๊ฐœ๋ฐœ์ž๊ฐ€ JPA๋ฅผ ์ข€๋” ํŽธํ•˜๊ฒŒ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๊ฒŒ ๋„์™€์ฃผ๊ธฐ ์œ„ํ•ด Repository๋ผ๋Š” ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์ œ๊ณต (JPA๋ฅผ ์ถ”์ƒํ™” ์‹œํ‚จ๊ฒƒ)

Repository์ธํ„ฐํŽ˜์ด์Šค ๊ทœ์น™๋Œ€๋กœ ๋ฉ”์„œ๋“œ๋ฅผ ์ž‘์„ฑํ•˜๋ฉด Spring์ด ์•Œ์•„์„œ JPA๋ฅผ ์ด์šฉํ•˜์—ฌ ์ ํ•ฉํ•œ ์ฟผ๋ฆฌ๋ฅผ ๋‚ ๋ฆฌ๋Š” ๊ตฌํ˜„์ฒด๋ฅผ ๋งŒ๋“ค์–ด BEAN์œผ๋กœ ๋“ฑ๋ก ํ•ด์ฃผ๋Š” ๊ฒƒ. (์ •ํ™•ํžˆ๋Š” ๋ฉ”์„œ๋“œ๋ช…๊ฐ€์ง€๊ณ  ์ ํ•ฉํ•œ JPQL์„ ์ƒ์„ฑํ•ด์ค€๋‹ค.)

๊ณตํ†ต ์ธํ„ฐํŽ˜์ด์Šค์˜ ๊ตฌํ˜„์ฒด๋Š” SimpleJpaRepository์ด๋‹ค.

๋™์ž‘๊ณผ์ •

์•ฑ๊ณผ JDBC ์‚ฌ์ด์—์„œ ๋™์ž‘ํ•˜๋ฉฐ, JPA๋ฅผ ์‚ฌ์šฉ์‹œ JPA๋‚ด๋ถ€์—์„œ JDBC API๋ฅผ ์‚ฌ์šฉํ•ด DB์™€ ํ†ต์‹ ์„ ํ•œ๋‹ค.

์ธํ„ฐํŽ˜์ด์Šค๋งŒ ๋งŒ๋“ค์–ด๋„ ์‹คํ–‰ํ• ๋•Œ ์ธํ„ฐํŽ˜์ด์Šค๋“ค์„ ์ฐพ์•„์„œ ๊ตฌํ˜„์ฒด๋ฅผ ๋งŒ๋“ค๊ณ  ๋นˆ์œผ๋กœ ๋“ฑ๋กํ•ด์ค€๋‹ค.

์ €์žฅ/์กฐํšŒ ๊ณผ์ •

JPA์—๊ฒŒ ๊ฐ์ฒด๋ฅผ ๋„˜๊ธฐ๋ฉด JPA๋Š” ์—”ํ‹ฐํ‹ฐ๋ฅผ ๋ถ„์„ํ•˜์—ฌ, SQL๋ฌธ์„ ์ƒ์„ฑํ•˜๊ณ  ์ด๋ฅผ JDBC API๊ฐ€ DB์— ๋‚ ๋ฆฌ๊ณ  ๊ฒฐ๊ณผ๋ฅผ ๊ฐ์ฒด์— ๋งคํ•‘์‹œํ‚จ๋‹ค.

์žฅ์ 

  • SQL์˜ ์ฝ”๋“œ ๋ฐ˜๋ณต์„ ์ค„์—ฌ์ฃผ๊ณ , CRUD๋ฅผ ๊ฐ„๋‹จํ•˜๊ฒŒ ํ•  ์ˆ˜ ์žˆ์–ด ์ƒ์‚ฐ์„ฑ๊ณผ ์œ ์ง€๋ณด์ˆ˜๊ฐ€ ์šฉ์ดํ•˜๋‹ค.

  • ๊ฐ์ฒด์™€ RDB๊ฐ„์˜ ๋ชจ๋ธ๋ง์ด ๋‹ฌ๋ผ ๋ฐœ์ƒํ•˜๋Š” ํŒจ๋Ÿฌ๋‹ค์ž„ ๋ถˆ์ผ์น˜๋ฅผ ํ•ด๊ฒฐํ•  ์ˆ˜ ์žˆ๋‹ค.

    (๊ฐ์ฒด๋Š” ๋‹จ๋ฐฉํ–ฅ์˜ ์ƒ์†๊ด€๊ณ„์™€ ์ฐธ์กฐ๋ฅผ ํ†ตํ•œ ์—ฐ๊ด€๊ด€๊ณ„๋ฅผ ๊ฐ–๊ณ  RDB๋Š” ์ƒ์†๊ด€๊ณ„๊ฐ€ ์—†์ด ํ…Œ์ด๋ธ”๊ฐ„์˜ ์Šˆํผ-์„œ๋ธŒ ํƒ€์ž…๊ด€๊ณ„์˜ ์–‘๋ฐฉํ–ฅ ์—ฐ๊ด€๊ด€๊ณ„๋ฅผ ๊ฐ–๋Š”๋‹ค.)

  • ๋™์ผํ•œ ํŠธ๋žœ์žญ์…˜ ์•ˆ์—์„œ๋Š” ๊ฐ™์€ ์—”ํ„ฐํ‹ฐ๋ฅผ ๋ฐ˜ํ™˜ํ•˜์—ฌ ์บ์‹ฑ๊ธฐ๋Šฅ๊ณผ ๋™์ผ์„ฑ์„ ๋ณด์žฅํ•œ๋‹ค.

  • ํŠธ๋žœ์žญ์…˜์„ commitํ• ๋•Œ๊นŒ์ง€ ์“ฐ๊ธฐ ์ง€์—ฐ(๋ฒ„ํผ๋ง)์„ ์ง€์›ํ•˜์—ฌ ํ•œ๋ฒˆ์— SQL๋ฌธ์„ ๋ณด๋‚ผ ์ˆ˜ ์žˆ๋‹ค.

  • ๊ฐ์ฒด๊ฐ€ ์‹ค์ œ๋กœ ์‚ฌ์šฉ๋  ๋•Œ ๋กœ๋”ฉํ•˜๋Š” ์ง€์—ฐ ๋กœ๋”ฉ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

์‚ฌ์šฉ๋ฒ•

Repository ๋ฐฉ์‹์€ Entity์—์„œ Spring Data JPA์—์„œ ์ œ๊ณตํ•˜๋Š” JpaRepository์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์ƒ์†ํ•˜๊ธฐ๋งŒ ํ•ด๋„ ๋˜์–ด, ์ธํ„ฐํŽ˜์ด์Šค์— ๋”ฐ๋กœ @Repository๋ฅผ ์ถ”๊ฐ€ํ•  ํ•„์š”๊ฐ€ ์—†๋‹ค.

์ƒ์†๋ฐ›์„ ๋•Œ๋Š” JpaRepository<T,ID>์˜ ํ˜•ํƒœ๋กœ Entity์˜ ํด๋ž˜์Šค์™€ ID๊ฐ’์ด ๋“ค์–ด๊ฐ€๊ฒŒ ๋œ๋‹ค.

๊ธฐ๋Šฅ

  • save() : ๋ ˆ์ฝ”๋“œ ์ €์žฅ (INSERT, UPDATE)

  • findOne() : primary key๋กœ ๋ ˆ์ฝ”๋“œ ์ฐพ๊ธฐ

  • findAll() : ์ „์ฒด ๋ ˆ์ฝ”๋“œ ๋ถˆ๋Ÿฌ์˜ค๊ธฐ ( sort, pageable )

  • count() : ๋ ˆ์ฝ”๋“œ ๊ฐฏ์ˆ˜

  • delete() : ๋ ˆ์ฝ”๋“œ ์‚ญ์ œ

์œ„์˜ ๊ธฐ๋Šฅ์„ ์ œ์™ธํ•œ ๊ธฐ๋Šฅ์€ ๋ฉ”์„œ๋“œ๋ฅผ ์ถ”๊ฐ€ํ•˜์—ฌ ์‚ฌ์šฉ ํ•  ์ˆ˜ ์žˆ์œผ๋ฉฐ, ๋ช…๋ช… ๊ทœ์น™์€ Refernece๋ฅผ ์ฐธ์กฐํ•˜์ž.

  • findBy~ : ์ฟผ๋ฆฌ๋ฅผ ์š”์ฒญํ•˜๋Š” ๋ฉ”์„œ๋“œ

  • countBy~ : ์ฟผ๋ฆฌ ๊ฒฐ๊ณผ ๋ ˆ์ฝ”๋“œ ์ˆ˜๋ฅผ ์š”์ฒญํ•˜๋Š” ๋ฉ”์„œ๋“œ

๋ฉ”์„œ๋“œ์˜ ๋ฐ˜ํ™˜ํ˜•์ด Entity๊ฐ์ฒด์ด๋ฉด ํ•˜๋‚˜์˜ ๊ฒฐ๊ณผ, List์ด๋ฉด ๋ชจ๋“  ๊ฐ์ฒด๋ฅผ ์ „๋‹ฌ

JPA NamedQuery

@Entity
@NamedQuery(
  name = "Member.findByUsername",
  query = "select m from Member m where m.username = :username")
public class Member{
  //...
}
<named-query name="Member.findByUsername">
  <query><CDATA[
    select m
    from Member m
    where m.username = :username]>
  </query>
</named-query>

Entity์— ์–ด๋…ธํ…Œ์ด์…˜์ด๋‚˜ xmlํŒŒ์ผ์„ ์ด์šฉํ•ด์„œ ์ •์˜ํ•œ ๋‚ด์šฉ์„ ๊ฐ€์ง€๊ณ  Repository์— ํ•ด๋‹น ์ด๋ฆ„์œผ๋กœ ๋ฉ”์„œ๋“œ๋ฅผ ๋งŒ๋“ค๋ฉด NamedQuery์— ๋งค์นญ์‹œ์ผœ ์ƒ์„ฑํ•ด์ฃผ๊ณ  ๋งŒ์•ฝ NamedQuery๊ฐ€ ์—†๋‹ค๋ฉด ๋ฉ”์„œ๋“œ๋ช…์— ๋งž๋Š” JPQL์„ ์ž๋™์œผ๋กœ ์ƒ์„ฑํ•ด์ค€๋‹ค.

@Query

public interface MemberRepository extends JpaRepository<Memeber,Long>{
  @Query("select m from Memeber m where m.username = :username")
  Member findByusername(@Param("username") String username);
}

@Query ์–ด๋…ธํ…Œ์ด์…˜์„ ์ด์šฉํ•ด ์ธํ„ฐํŽ˜์ด์Šค ๋‚ด์—์„œ ์ง์ ‘ JPQL์„ ์ƒ์„ฑํ•  ์ˆ˜๋„ ์žˆ๊ณ , ์˜ต์…˜์œผ๋กœ natvieQuery = true์˜ต์…˜์„ ์ด์šฉํ•˜๋ฉด SQL๋ฌธ์œผ๋กœ ์ž‘์„ฑํ•  ์ˆ˜๋„ ์žˆ๋‹ค.

@Modifying

๋ฒŒํฌ ์ฟผ๋ฆฌ๋ฅผ ๋‚ ๋ฆด ๋•Œ ์‚ฌ์šฉํ•˜๋Š” ์–ด๋…ธํ…Œ์ด์…˜์ด๋‹ค.

@Modifying(clearAutomatically = true)
@Query("update Product p set p.price = p.price * 1.1 where p.stockAmount < :stockAmount")
int bulkPriceUp(@Param("stockAmount") String stockAmount);

clearAutomatically์˜ต์…˜์œผ๋กœ ์ฟผ๋ฆฌ ํ›„ ์˜์†์„ฑ ์ปจํ…์ŠคํŠธ๋ฅผ ์ดˆ๊ธฐํ™” ํ•˜๋Š” ์˜ต์…˜์„ ์ค„ ์ˆ˜ ์žˆ๋‹ค.


Reference

https://docs.spring.io/spring-data/jpa/docs/1.10.1.RELEASE/reference/html/#jpa.sample-app.finders.strategies

https://docs.jboss.org/hibernate/orm/5.4/userguide/html_single/Hibernate_User_Guide.html

PreviousSpring DataNextJPA ์–ด๋…ธํ…Œ์ด์…˜

Last updated 3 years ago