MySQL(7)
-
스프링부트에서 JPA-MySQL 연동하기 3: 1:N 연관관계 설정
지난 번까지는 각 테이블 간의 연관관계를 하나도 지정해주지 않고 기본적인 작동 방식만 알아보았다. 이번에는 PK-FK로 연관된 테이블의 관계를 엔티티에서 역시 맺어보고자 한다. 이 프로젝트의 테이블들의 상관관계는 다음과 같다. 상품과 관련된 prod 테이블이 있고, 상품을 조회하면 글/이미지 쌍으로 디테일이 있는 prod_detail 테이블이 있다. 두 테이블은 1(prod) : N(prod_detail) 관계이다. prod 테이블의 no 컬럼이 PK이며, prod_detail의 prod_no 컬럼이 prod 테이블을 참조하는 컬럼이다. 상품이 삭제되면 디테일도 삭제되어야 하기 때문에 양방향 관계를 가진다. 이 방향이라는 것은, 양방향/ 단방향이 있다. 테이블 개념에서 볼 때 PK-FK로 연관관계를 맺고..
2020.03.26 -
스프링부트에서 JPA-MySQL 연동하기 2: 레포지토리 설정
목차 1. DAO, Service, Controller 작성 2. REST API를 사용하여 회원가입 기능 구현 이번에는 간단히 CRUD 기능을 사용하기 위해 DAO, Service, Controller를 작성하는 것에 대해 알아보고자 한다. 1. DAO, Service, Controller 작성 MyBatis 환경에서 DAO와 동일한 개념이 레포지토리 인터페이스이다. 여기서 JPA의 특징적인 점은 별도의 구현 클래스를 만들지 않고 인터페이스만 정의함으로써 기능을 사용할 수 있다는 것이다. 여기서 보통 Spring Data 모듈에서 제공하는 CrudRepository를 상속한다. 추가적으로 페이징 처리를 할 경우에는 PagingAndSortingRepository를 사용한다. package com.cod..
2020.03.24 -
스프링부트에서 JPA-MySQL 연동하기 1: 엔티티 설정
목차 1. perspective 설정 2. 새 프로젝트 생성 3. application.properties 작성 4. 엔티티 클래스 매핑 * Git Repository에 업로드 기존에 MyBatis로 DB를 사용했던 것을 JPA로 전환하려고 한다. 작업한 코드는 여기에 업로드하였다. 1. perspective 설정 Spring 선택 2. 새 프로젝트 생성 Spring Starter Project 선택 정보 입력 5가지 의존성 추가 3. application.properties 작성 # DataSource Setting spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1..
2020.03.23 -
MySQL 전체 텍스트 검색
전체 텍스트 검색은 긴 문자의 텍스트 데이터를 빠르게 검색하기 위한 MySQL의 부가적인 기능이다. 전체 텍스트 검색을 사용하면 기사의 내용에 포함된 여러 단어들에 인덱스가 설정되어서 검색 시에 인덱스를 사용하여 검색 속도가 월등히 빨라진다. 전체 텍스트 인덱스는 신문기사와 같이 텍스트로 이루어진 문자열 데이터의 내용을 가지고 생성한 인덱스를 말한다. SELECT * FROM 신문기사_테이블 WHERE 신문기사내용 '교통 사고의 증가로 인해 오늘 ----'; SELECT * FROM 신문기사_테이블 WHERE 신문기사내용 LIKE '교통%'; 인덱스가 정렬되어 있으므로, 해당되는 내용이 인덱스를 통해서 빠르게 검색함. SELECT * FROM 신문기사_테이블 WHERE 신문기사내용 LIKE '%교통%';..
2020.03.19 -
MySQL 잠금기능
잠금(Locking)을 알기 위해선 그 전에 동시성 제어(Concurrency Control)를 먼저 짚고 넘어가야 한다. 동시성 제어는 다중 사용자 환경을 지원하는 데이터베이스 시스템에서 동시에 실행되는 여러 트랜잭션 간의 간섭으로 문제가 발생하지 않도록 트랜잭션의 실행 순서를 제어하는 기법이다. 한 트랜잭션을 실행하는 중에 다른 트랜잭션이 간섭하게 되면 갱신 분실(lost update), 연쇄 복귀(cascading rollback) 또는 회복 불가능(unrecoverability), 불일치 분석(inconsistent analysis) 등과 같은 문제들이 발생할 수 있다. 동시성 제어는 다시 비관적 동시성 제어 (Pessimistic concurrency Control)와 낙관적 동시성 제어(Opt..
2020.02.20 -
MySQL view(뷰)
뷰의 작동 방식은 다음과 같다. 뷰를 생성하여 SELECT문으로 데이터를 조회하면 테이블과 동일한 모양으로 확인할 수 있다. 뷰를 사용하는 이유는 다음과 같은 장점이 있기 때문이다. 보안에 도움이 된다: 위와 같은 뷰에는 사용자의 이름과 주소만 있을 뿐, 시용자의 중요한 개인정보인 출생년도, 연락처, 키, 가입일 등은 들어 있지 않다. 예를 들어 다른 사용자에게 무언가 작업을 맡겼을 때 연락처 등의 중요한 정보에는 접근하지 않고 이름과 주소 데이터만 가지고 작업하도록 할 때 뷰를 사용할 수 있다. 복잡한 쿼리를 단순화할 수 있다: 이렇게 줄도 길고 여러 조건이 들어간 쿼리를 자주 사용하게 될 경우 이 쿼리문을 뷰로 만들어 놓으면 편리하다. CREATE VIEW Statement ALTER VIEW Sta..
2020.02.17