Spring 72

@Json~~~ 관련 annotation 정리

우리가 클래스를 하나 만들었다고 가정하자. ... @Data @AllArgsConstructor @NoArgsConstructor @Entity public class Users { @Id @GeneratedValue private Integer id; @Size(min = 2, message="Name은 2글자 이상 입력해 주세요.") private String name; @Past private Date joinDate; private String password; private String ssn; } 위의 정보를 바탕으로 사용자 정보를 조회하고 싶은데 조회할 때 마다 아니... password가 같이 넘어오게 된다. 이러한 경우 조회시 필드에서 제외하고 싶은 성분을 @JsonIgnore 어노테이션..

Bean이란?

Bean이란 무엇인가? 콩인가? (노잼...) Spring으로 개발을 하다보면 Bean이라는 말을 굉장히 많이 사용할 것이다. (그렇다고 해줘!) 필자는 어떤 것을 이해했다는 기준을 한줄로 정리할 수 있느냐로 보고있다. Bean은 Spring Framework의 핵심 개념이라고 하는데 과연 정확히 한줄로 어떻게 설명할 수 있을까? 그럴 수 있었으면 내가 이것을 작성하지 않았을 것이다. (머쓱...) 그래서 이번 블로그 정리를 통해 Bean이란 무엇이고 이를 어떻게 관리하고 등록해서 사용할 수 있는지 정리하려고 한다. (빵긋 ^^) 1. The Definition of Spring Bean 이에 대한 정보를 baeldung 사이트에서 확인할 수 있었다. 참고 : https://www.baeldung.com..

MVC 어노테이션 정리

필자는 최근에 spring 강의를 뒤져가며 공부를 다시 하고 있다. 그전에는 그냥 사용하기에 급급했기에 비슷한 어노테이션이 나오게 되면 차이점을 잘 몰랐다. 그렇기에 이렇게 정리를 하고자 한다. 1. @Controller vs @RestController @Controller 는 Spring MVC (Model - View - Controller)패턴에서 View(화면)을 반환할 때 사용하는 어노테이션이다 . 반환시에 논리적인 view 를 해당 위치에 있는 view template을 찾아 화면을 구성해준다. @RestController 는 Spring MVC 패턴에서 화면이 아닌 데이터를 반환하고 싶을 때 사용한다. 사실 RestController도 결국 열어보면 @Controller + @Respons..

스프링부트 & jpa1 / 2 - 요구사항 분석

개발을 하기 전에 무엇을 개발할지 알아야 한다 개발 예정인 화면이다! 회원, 주문, 상품의 관계 - 회원은 여러 상품을 주문할 수 있다. 그리고 한 번 주문할 때 여러 상품을 선택할 수 있으므로 주문과 상품은 다대다 관계다. 하지만 이런 다대다 관계는 관계형 데이터베이스는 물론이고 엔티티에서도 거의 사용하지 않는다. 따라서 그림처럼 주문상품이라는 엔티티를 추가해서 다대다 관계를 일대다, 다대일 관계로 풀어냈다. 근데 다대다 관계는 쓰면 안돼니 일대다, 다대일로 풀어낼 것임

Spring 2021.07.26

스프링부트 & jpa1 / 1 - 프로젝트 생성

드디어 개념 강의가 끝났고... 실제로 코딩을 한다고 한다 설정은 밑에 보이는 대로 했다. Gradle , Java, Jar, 11 여기서 나는 Thymeleaf가 있는데 JSP와 비슷한건데 김영한 팀장님께서는 jsp를 잘 안쓰는 추세라고 하신다. 추가할 Dependencies는 Spring Web, Thymeleaf, Spring Data JP, H2 Database, Lombok이 있다. 다 됏으면 genereate the project를 해서 다운받으면 된다.. 그리고 프로젝트를 원하는 경로에 놓고 open하면 된다! 나는 IntelliJ IDEA를 사용해서 공부를 진행중이다. 프로잭트 로딩이 좀 걸린다. 진정하고 기다리자! build.gradle파일을 보면 내가 설정한 정보가 등록된것을 확인할 수..

Spring 2021.07.25

16. 경로 표현식 / 페치조인

상태 필드(state field) : 단순히 값을 저장하기 위한 필드 연관 필드(association field): 연관관계를 위한 필드 - 단일 값 연관 필드: @ManyToOne, @OneToOne, 대상이 엔티티 - 컬렉션 값 연관 필드: @OneToMany, @ManyToMany, 대상이 컬렉션 아예 묵시적 내부 조인 안쓰는게 좋암~~!!! => 나중에 유지보수가 힘듬 페치 조인(이거는 실무는 엄청 중요함) SQL 조인 종류 X JPQL에서 성능 최적화를 위해 제공하는 기능 연관된 엔티티나 컬렉션을 SQL한 번에 함께 조회하는 기능 join fetch 명령어 사용 페치 조인 ::= [LEFT [OUTER] | INNER] JOIN FETCH 조인경로 package jqpl; import javax..

Spring 2021.07.25

15. 조인

내부조인 : SELECT m FROM Member m [INNER] JOIN m.team t 외부조인 : SELECT m FROM Member m LEFT [OUTER] JOIN m.team t 세타 조인 : select count(m) from Member m, Team t where m.username = t.name 1. 조인 대상 필터링 예) 회원과 팀을 조인하면서, 팀 이름이 A인 팀만 조인 JPQL : SELECT m, t FROM Member m LEFT JOIN m.team t on t.name = 'A' 실행된 SQL : SELECT m.*, t.* FROM Member m LEFT JOIN Team t on m.TEAM_ID = t.id and t.name = 'A' 2. 연관관계 없는..

Spring 2021.07.24

14. 기본 문법과 쿼리 API

JPQL(Java Persistence Query Language) JPQL은 객체지향 쿼리 언이이다. 따라서 테이블을 대상으로 쿼리하는 것이 아니라 엔티티 객체를 대상으로 쿼리한다. JPQL은 SQL을 추상화해서 특정 데이터베이스 SQL에 의존하지 않는다. JQPL은 결국 SQL로 변환된다. 근데 위치 기반 쓰면 안됀다! 이름을 적는것은 위치가 바뀌어도 버그가 안생김! 무조건 이름 기반으로 작성한다 프로젝션 SELECT절에 조회할 대상을 지정하는 것 프로젝션 대상 : 엔티티, 임베디드 타입, 스칼라 타입(숫자, 문자등 기본 데이터 타입) SELECT m FROM Member m => 엔티티 프로젝션 SELECT m.team FROM Member m => 엔티티 프로젝션 SELECT m.address F..

Spring 2021.07.24

13. 객체지향 쿼리 언어(JPQL)

이제 객체 지향 쿼리에 대해 알아볼것임! JPQL jpa Criteria QueryDSL 네이티브 SQL JDBC API 직접 사용, MyBatis, SpringJdbcTemplate함께 사용 JPQL 소개 가장 단순한 조회 방법 1. EntityManager.find() 2. 객체 그래프 탐색(a.getB().getC()) JPA를 사용하면 엔티티 객체를 중심으로 개발 문제는 검색 쿼리이다! 검색을 할 떄도 테이블이 아닌 엔티티 객체를 대상으로 검색 모든 DB 데이터를 객체를 변환해서 검색하는 것은 불가능 애플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검색 조건이 포함된 SQL이 필요 그래서... JPA는 SQL를 추상화한 JPQL이라는 객체 지향 쿼리 언어를 제공한다 SQL과 문법이 유사하다..

Spring 2021.07.24

12. 값 타입의 비교 ~

값 타입 : 인스턴스가 달라도 그 안에 값이 같으면 같은 것으로 봐야 함 int a = 10; int b = 20; public class ValudMain{ public static void main(String args){ int a = 10; int b = 10; System.out.println("a == b " + (a == b)); Address address1 = new Address ("city", "street", "10000"); Address address1 = new Address ("city", "street", "10000"); System.out.println("address1 == address2 : " + (address1== address2)); } } 위에 결과는 알아서..

Spring 2021.07.22