NativeSQL
jpql์ ํ์ค SQL์ด ์ง์ํ๋ ๋๋ถ๋ถ์ ๋ฌธ๋ฒ๊ณผ SQLํจ์๋ค์ ์ง์ํ์ง๋ง, ํน์ ๋ฐ์ดํฐ๋ฒ ์ด์ค์ ์ข ์์ ์ธ ๊ธฐ๋ฅ์ ์ง์ํ์ง ์์ ์๋ฅผ ๋ค๋ฉด ํน์ ๋ฐ์ดํฐ๋ฒ ์ด์ค๋ง ์ง์ํ๋ ํจ์, ๋ฌธ๋ฒ, SQL์ฟผ๋ฆฌ ํํธ ์ธ๋ผ์ธ ๋ทฐ, union, intersect ์คํ ์ด๋ ํ๋ก์์ ๋ฑ๋ฑ์ด ์๋ค ๋ค์ดํฐ๋ธ SQL์ ์ฌ์ฉํ๋ ์ด์ ๋ JPQL์ ์ฌ์ฉํ ์ ์๋ ๊ฒฝ์ฐ์์ ์ง์ SQL์ ์ฌ์ฉํ๊ธฐ ์ํด์ ์ฌ์ฉํ๋ค JPQL์ ์ฌ์ฉํ๋ฉด JPA๊ฐ SQL์ ์์ฑํ๋๋ฐ, ๋ค์ดํฐ๋ธSQL์ ๊ฐ๋ฐ์๊ฐ ์ง์ ์ ์ํ๋ค๋ ์ ๊ทธ๋ผ jdbc์ api๋ฅผ ์ฌ์ฉํ๋ ๊ฒ๊ณผ jpa๋ฅผ ์ฌ์ฉํ๋ ๊ฒ์ ์ด๋ค ์ฐจ์ด๊ฐ ์๋? -> ๋ค์ดํฐ๋ธSQL์ ์ฌ์ฉํ๋ค๋ฉด ์ํฐํฐ๋ฅผ ์กฐํํ๋ ๊ฒ์ด ๊ฐ๋ฅํ๊ณ JPA๊ฐ ์ง์ํ๋ ์์์ฑ ์ปจํ ์คํธ์ ๊ธฐ๋ฅ์ ๊ทธ๋๋ก ์ฌ์ฉ -> JDBC API๋ฅผ ์ง์ ์ฌ์ฉํ๋ฉด ๋จ์ํ๊ฒ ๋ฐ์ดํฐ๋ฅผ ๋์ด
##๋ค์ดํฐ๋ธ SQL์ ์ฌ์ฉ ๋ค์ดํฐ๋ธ ์ฟผ๋ฆฌ api์๋ 3๊ฐ์ง๊ฐ ์กด์ฌ
์ํฐํฐ ์กฐํ
๋ญ ๊ทธ๋ ๊ฒ ๋ค๋ฅธ์ ์ ์๋ค..! ๋ค์ดํฐ๋ธ SQL๋ก SQL๋ง ์ง์ ์ฌ์ฉํ ๋ฟ์ด์ง ๋๋จธ์ง๋ JPQL์ ์ฌ์ฉํ ๋์ ๊ฐ์ผ๋ฉฐ ์กฐํํ ์ํฐํฐ๋ ์์์ฑ ์ปจํ ์คํธ๋ก ๊ด๋ฆฌ๋๋ค
๊ฐ ์กฐํ
๋จ์ํ๊ฒ ๊ฐ์ผ๋ก๋ง๋ ์กฐํํ๋ ๊ฒ์ด ๊ฐ๋ฅํ๋ค
์ํฐํฐ๋ก ์กฐํํ๋ ๊ฒ์ด ์๋๋ผ ๋จ์ํ๊ฒ ๊ฐ์ผ๋ก ์กฐํํ๊ธฐ ์ํด์ class๋ฅผ ๋ ๋ฒ์จฐ ํ๋ผ๋ฏธํฐ์ ์ค์ ํด์ฃผ์ง ์์ ๋ชจ์ต์ด๊ณ ์กฐํ๋ ๊ฐ์ ์ํฐํฐ๊ฐ ์๋ ๊ฐ์๋ค๊ฐ ๋ฃ์ ๊ฒ์ด๊ธฐ ๋๋ฌธ์ Object[]์ ๋ด์์ ๋ฐํํ๋ค ์ฌ๊ธฐ์๋ ์ค์นผ๋ผ ๊ฐ๋ค์ ์กฐํํ์ ๋ฟ์ด๊ธฐ ๋๋ฌธ์ ๊ฒฐ๊ณผ๋ฅผ ์์์ฑ ์ปจํ ์คํธ๊ฐ ๊ด๋ฆฌํ์ง ์๋๋ค๋ ์ !!
๊ฒฐ๊ณผ ๋งคํ ์ฌ์ฉ
๋ง์ฝ์ ์ํฐํฐ์ ์ค์นผ๋ผ ๊ฐ์ ํจ๊ป ์กฐํํ๋ ๊ฒ ์ฒ๋ผ ๋งคํ์ด ๋ณต์กํด์ง๋ฉด @SqlResultSetMapping์ ์ ์ํด์ ๊ฒฐ๊ณผ ๋งคํ์ ์ฌ์ฉํด์ผ ํจ ์ฌ์ฉํ๋ ์์๋ฅผ ๋ณด์
์ด๋ ๊ฒ ๋ ๋ฒ์งธ ํ๋ผ๋ฏธํฐ์ ๊ฒฐ๊ณผ ๋งคํ ์ ๋ณด์ ์ด๋ฆ์ด ์ฌ์ฉ๋์์ ์ด๋ ๊ฒ ๊ฒฐ๊ณผ ๋งคํ์ ํด๋ณผ ์ ์๋ค๋ ์ ์ด๋ค
memberWithOrderCount์ ๊ฒฐ๊ณผ ๋งคํ์ Member ์ํฐํฐ์ ORDER_COUNT ์นผ๋ผ์ ๋งคํํ๋๋ฐ, ๋งคํํ๋ ๊ฒ์ ๋ค์์ ์ํฐํฐ์ ๋ค์์ ์ปฌ๋ผ์ ์ด์ด์ฃผ๋ ๊ฒ์ด ๊ฐ๋ฅํ๋ค @EntityResult ์ด์ธ์๋ @FieldResult ๋ผ๋ ์ ๋ ธํ ์ด์ ์ ์ฌ์ฉํด์ ์ปฌ๋ผ๋ช ๊ณผ ํ๋๋ช ์ ์ง์ ๋งคํํ๋ ๊ฒ๋ ๊ฐ๋ฅ
๊ฒฐ๊ณผ ๋งคํ ์ ๋
ธํ
์ด์
@SqlResultSetMapping
name : ๊ฒฐ๊ณผ ๋งคํ ์ด๋ฆ
entities : @EntityResult๋ฅผ ์ฌ์ฉํด์ ์ํฐํฐ๋ฅผ ๊ฒฐ๊ณผ๋ก ๋งคํ
columns : @ColumnResult๋ฅผ ์ฌ์ฉํด์ ์ปฌ๋ผ์ ๊ฒฐ๊ณผ๋ก ๋งคํ
@EntityResult
entityClass : ๊ฒฐ๊ณผ๋ก ์ฌ์ฉํ ์ํฐํฐ ํด๋์ค๋ฅผ ์ง์
fields : @FieldResult์ ์ฌ์ฉํด์ ๊ฒฐ๊ณผ ์ปฌ๋ผ์ ํ๋์ ๋งคํ
discriminatorColumn : ์ํฐํฐ์ ์ธ์คํด์ค ํ์ ์ ๊ตฌ๋ถํ๋ ํ๋(์์ํ ๋ ์ฌ์ฉ)
@FieldResult
name : ๊ฒฐ๊ณผ๋ฅผ ๋ฐ์ ํ๋๋ช
column : ๊ฒฐ๊ณผ ์ปฌ๋ผ๋ช
@ColumnResult
name : ๊ฒฐ๊ณผ ์ปฌ๋ผ๋ช
Named ๋ค์ดํฐ๋ธ SQL
JPQL์์ ์ฒ๋ผ ๋ค์ดํฐ๋ธSQL๋ Named ๋ค์ดํฐ๋ธ SQL์ ์ฌ์ฉํด์ ์ ์ SQL์ ์์ฑํ ์ ์๋ค
@NamedNativeQuery ์ ๋ ธํ ์ด์ ์ ์ฌ์ฉํด์ Named๋ค์ดํฐ๋ธ ์ฟผ๋ฆฌ๋ฅผ ๋ฑ๋กํ๊ณ ์ฌ์ฉ์ ์ด๋ ๊ฒ
์ฌ์ฉ๋ฟ๋ง ์๋๋ผ ๊ฒฐ๊ณผ ๋งคํ ์์ฒด๋
Named ๋ค์ดํฐ๋ธ ์ฟผ๋ฆฌ์์ ์กฐํ ๊ฒฐ๊ณผ๋ฅผ ๋งคํ๊น์ง memberWithOrderCount์ ๋ง์ถฐ์คฌ๊ณ
์ด๋ ๊ฒ ์ฌ์ฉํ๋ค
@NamedNativeQuery
name : ๋ค์๋ ์ฟผ๋ฆฌ ์ด๋ฆ(required)
query : SQL ์ฟผ๋ฆฌ(required)
hints : ๋ฒค๋ ์ข ์์ ์ธ ํํธ
resultClass : ๊ฒฐ๊ณผ ํด๋์ค
resultSetMapping : ๊ฒฐ๊ณผ ๋งคํ ์ฌ์ฉ
๋ค์ดํฐ๋ธ SQL ์ ๋ฆฌ
๋ค์ดํฐ๋ธ SQL์ JPQL์ด ์๋์ผ๋ก ์์ฑํ๋ SQL์ ์๋์ผ๋ก ์ง์ ์ ์ํ๋ ๊ฒ์ด ์๋๊ธฐ ๋๋ฌธ์ JPA๊ฐ ์ ๊ณตํ๋ ๊ธฐ๋ฅ ๋๋ถ๋ถ ๊ทธ๋๋ก ์ฌ์ฉ ๊ฐ๋ฅ ๊ทผ๋ฐ ์ด๋ ๊ฒ ๋ ๊ฒ์ผ๋ก ์ฌ์ฉํ๋ ๊ฒ์ ๋ฐ์ดํฐ๋ฒ ์ด์ค ๊ฐ์ ์ด์์ฑ๋ ๋จ์ด์ง๊ณ ์ข ์์ ์ด๋ผ๋ ์ ..!
์คํ ์ด๋ ํ๋ก์์ (Stored Procedure)
๊ฐ๋ ์ผ๋ก๋ ์ผ๋ จ์ ์ฟผ๋ฆฌ๋ฅผ ๋ง์น ํ๋์ ํจ์์ฒ๋ผ ์คํ ํ๊ธฐ ์ํ ์ฟผ๋ฆฌ์ ์งํฉ์ด๋ค
์์๋ก๋ ์ ๋ ฅ๊ฐ์ 2๋ฐฐ๋ก ๋ง๋ค์ด์ฃผ๋ proc_multiply๊ฐ ์๋๋ฐ jpa๋ฅผ ํธ์ถํ๋๊ฑด
์ด๋ ๊ฒ ์ฌ์ฉํ๋ฉด out์ 200
๋ญ ๋์ถฉ ์ด๋ฐ ๊ฐ๋ ์ ์ด๋ ๊ฒ ์ฌ์ฉํ๋ค๊ณ ๋ง ์์๋๊ณ ๋์์ข ๋ณด์ด๋ฉด ๋ค์ ๊ณต๋ถํ์
Last updated
Was this helpful?