[Web] Creating Web Applications with Oracle DB Basics

Updated:

VO

DB annotations

  • @Entity(name=”테이블명”)
  • @Id // PK
  • @column(name=”컬럼명”)
  • @Enumerated // EnumType.ORDINAL: 정수, EnumType.STRING: 문자열 타입의 상수로 전달
  • @OneToMany // FK. 엔티티 간의 관계를 나타냄. (일대일, 일대다(多), 다대일, 다대다,…)
    • fetch = FetchType.LAZY // 생략 가능. 검색 시 줄 수가 많으면 처리 시간이 오래 걸림. 이걸 개선하기 위해 씀. 참고: json 형태의 결과를 만들 때 발생할 수 있는 리스크를 막기 위해선 안 쓰는 게 낫다.
  • @GeneratedValue // 시퀀스 생성. EX. 주문번호 같은 건 사용자 지정보단 자동 할당하는 편이 편리하다.
    • @SequenceGenerator // 오라클DB를 쓸 때만 사용하는 annotation. (MySQL 같은 데엔 필요 없다! => 얜 자동으로 시퀀스 지정해줌.)
    • (name=””, sequenceName=””) // DB상에서 value(seq.nextval, ???,…)로 매핑
  • @JoinColumn // 데이터의 무결(無抉)성 보장 위해 사용 @JoinColumn(name=”pnum”, nullable=false) // nullable=false: NOT NULL 조건. cf. @Column(nullable=false) private Product pnum; // PRODUCT 테이블의 PK에 FK 설정 —이렇게 해도 된다— @JoinTable(name=”product”) private int pnum; => 똑같은 명령도 목적에 따라 다르게 구현할 수 있다.

DAO

Repository: 범용으로 사용될 만한 인터페이스를 정리해두고 구현까지 해줌. 인터페이스 형태이기 때문에 기본 내장메서드 외에 필요한 기능이 있다면 메서드를 추가하면 됨. 단, 메서드 이름에는 규칙이 있어 이 점을 주의해서 만들어야 함!

EX. select문 » 반환타입 findBy컬럼명(); 반환타입 findBy컬럼명like();

Service

@Service // Service클래스임을 명시

@Autowired // DAO와 연결

Controller

@Controller

@Autowired

@GetMapping // 사용자한테 어떻게 보여지도록 할 건지

@PostMapping // 해당 페이지에서 어떤 동작을 수행할 건지

@RequestMapping

Leave a comment