백엔드 15

7. AOP

AOP 필요 상황  - 모든 메소드의 호출 시간을 측정- 공통 관심 사항 (cross-cutting concern) vs 핵심 관심 사항 (core concern)- 회원 가입 시간, 회원 조회 시간 측정 등 MemberServie 회원 조회 시간 측정package hello.hellospring.service;@Transactionalpublic class MemberService { /** * 회원가입 */ public Long join(Member member) { long start = System.currentTimeMillis(); try { validateDuplicateMember(member); //중복 회원 검증 memberRepository..

6. 스프링 DB 접근 기술

H2 데이터베이스 설치: 개발이나 테스트 용도로 가볍고 편리한 DB, 웹 화면 제공 데이터베이스 파일 생성- jdbc:h2:~/test : 최초 1회 실행- ~/test.mv.db : 파일 생성 확인* 이후 접속 시에는 jdbc:h2:tcp://localhost/~/test 사용 테이블 생성https://github.com/smallsilverwest/EWHA.W.UNIV_ECC_Spring/blob/main/sql/ddl.sqlH2 데이터베이스에 접근해 member 테이블 생성 순수 Jdbc 환경 설정https://github.com/smallsilverwest/EWHA.W.UNIV_ECC_Spring/blob/main/build.gradlejdbc, h2 데이터베이스 관련 라이브 추가 https://..

5. 회원 관리 예제 - 웹 MVC 개발

회원 웹 기능: 홈 화면 추가 홈 컨드롤러 추가package hello.hellospring.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.GetMapping;@Controllerpublic class HomeController { @GetMapping("/") public String home() { return "home"; }} 회원 관리용 홈 Hello Spring 회원 기능 회원 가입 회원 목록   회원 웹 기능: 등록 회원 등록 폼 컨트롤러@Controllerpublic class MemberController { ..

4. 스프링 빈과 의존관계

컴포넌트 스캔과 자동 의존관계 설정: 회원 컨트롤러가 회원서비스와 회원 리포지토리를 사용할 수 있도록 의존관계 준비 회원 컨드롤러 의존관계 추가package hello.hellospring.controller;import hello.hellospring.service.MemberService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller; @Controllerpublic class MemberController { private final MemberService memberService; @Autowired public MemberContr..

3. 회원 관리 예제 - 백엔드 개발

비즈니스 요구사항 - 데이터: 회원 ID, 이름- 기능: 회원 등록, 조회- 데이터 저장소: 미정 | 컨트롤러: 웹 MVC의 컨트롤러 역할 | 서비스: 핵심 비즈니스 로직 구현 | 리포지토리: 데이터베이스에 접근, 도메인 객체를 DB에 저장하고 관리 | 도메인: 비즈니스 도메인 객체ex) 회원, 주문, 쿠폰 등 주로 DB에 저장하고 관리 - 데이터 저장소가 선정되지 않았으므로 인터페이스 구현 클래스를 변경 가능하도록 설계* 이때, 데이터 저장소는 RDB, NoSQL 등 다양한 선택지 고려- 초기 개발 단계에서는 구현체로 가벼운 메모리 기반 데이터 저장소 사용 회원 도메인과 리포지토리 만들기 회원 객체package hello.hellospring.domain;public class Member { pri..

2. 스프링 웹 개발 기초

정적 컨텐츠https://github.com/smallsilverwest/EWHA.W.UNIV_ECC_Spring/blob/main/src/main/resources/static/hello-static.html정적 컨텐츠 입니다.* 실행 시 http://localhost:8080/hello-static.htmlMVC와 템플릿 엔진 MVC: Model, View, Controller Controller@Controllerpublic class HelloController { @GetMapping("hello-mvc") public String helloMvc(@RequestParam("name") String name, Model model) { model.addAttribute("name", name);..

8. 데이터베이스 설계

34. 데이터베이스 설계 데이터베이스 설계터이터베이스의 스키마 내에 테이블, 인덱스, 뷰 등의 데이터베이스 객체를 정의, 테이블 간의 관계를 고려해 테이블 이름, 열, 자료형을 결정스키마 내에 정의한다는 의미에서 '스키마 설계'라고 부르기도 함 | 물리명: CREATE TABLE에 지정하는 테이블 이름아니 열 이름 | 논리명: 설계상의 이름 | 수치 자료형: 금액이나 개수와 같은 수치 데이터만 다룰 수 있는 열 | 문자열형: 제조번호와 같이 알파벳을 다루는 데이터 LOB(Large Object)문자열형에서 주로 사용하는 VARCHAR형보다 담을 수 있는 용량이 큰 문자열단, 인덱스를 지정할 수 없다는 제약이 있음 AUTO_INCREMENT기본키로 지정할 열이 생각나지 않는 경우 자동증가 열을 사용해 기본..

7. 복수의 테이블 다루기

31. 집합 연산 SQL과 집합SELECT 명령을 실행하면 데이터베이스에 질의, 그 결과로 몇 개의 행이 출력되는 과정이때, 반환된 결과 전체를 하나의 집합으로 보고 집합 내 하나의 행을 하나의 요소로 간주 UNION집합의 연산 중 '합집합'을 위해 사용하는 명령어합집합이란 집합을 서로 더하는 것을 의미하며 A∪B와 같이 표현SQL에서 SELECT 명령의 실행 결과를 하나의 집합으로 다룰 수 있으며 UNION은 다음과 같이 표현mysql> SELECT * FROM t1;mysql> SELECT * FROM t2;mysql> SELECT * FROM t1; UNION SELECT * FROM t2; // 집합의 합집합 연산* 합집합 시, 동일 행은 한 개만 출력: 각각의 SELECT 명령의 열의 내용은 서..

6. 데이터베이스 객체 작성과 삭제

25. 데이터베이스 객체 데이터베이스 객체테이블이나 뷰, 인덱스 등 데이터베이스 내에 정의하는 모든 것을 일컫는 말이때, 객체는 데이터베이스 내에서 실체와 이름을 가지며 데이터베이스 내에서 객체를 작성할 때는 이름이 겹치지 않도록 해야 함 데이터베이스 객체의 명명규칙 및 제약 사항- 기존 이름이나 예약어와 중복하지 않는다.- 숫자로 시작할 수 있다.- 언더스코어 외 기호는 사용 불가하다- 한글을 사용할 때는 더블쿼트로 둘러싼다.- 시스템이 허용하는 길이를 초과하지 않는다. 스키마객체의 이름이 같아도 스키마가 서로 다르다면 상관없으며 데이터베이스 객체는 스키마 객체라 불리기도 함SQL 명령의 DDL을 이용하여 정의하며 어떤 것이 스키마가 되는지는 데이터베이스 제품에 따라 다름 - 스키마 설계: 실제로 데이..