전체 글 23

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을 이용하여 정의하며 어떤 것이 스키마가 되는지는 데이터베이스 제품에 따라 다름 - 스키마 설계: 실제로 데이..

5. 집계와 서브쿼리

20. 행 갯수 구하기 집계: 집합으로 부터 하나의 값을 계산하는 과정집계 함수: 하나의 행에 대해 하나의 값을 반환하는 일반적인 함수와 다르게 복수의 값에서 하나의 값을 계산* SELECT 구문에서의 집계함수는 WHERE 구의 유무와 관계없이 결과값으로 하나의 행을 반환 집계함수 [집합] 형태로 사용하며 대표적인 집계함수는 다음과 같음- COUNT, SUM, AVG, MIN, MAX... COUNT인수로 지정된 집합의 행 개수를 반환mysql> SELECT COUNT(*) FROM t1; // 테이블 전체의 행 개수 반환mysql> SELECT COUNT(*) FROM t1 WHERE name='A'; // WHERE구의 조건에 해당하는 행의 개수 반환* SELECT보다 WHERE 구를 먼저 처리하므로..

4. 데이터의 추가, 삭제, 갱신

16. 행 추가하기 INSERT행을 추가하는 함수mysql> INSERT INTO t1 VALUES (1,'ABC','2024-10-05');mysql> INSERT INTO t1 (a,b) VALUES ('XYZ',2); // a,b열만 지정해 행 추가 NOT NULL 제약NOT NULL 제약이 걸려있는 열은 NULL 값을 허용하지 않음 DAFUALT명시적으로 값을 지정하지 않은 경우 사용하는 초기값을 의미테이블을 정의할 때 지정할 수 있으며 열을 지정해 행을 추가할 때 지정하지 않은 열은 Deafult 값을 사용하여 저장mysql> INSERT INTO t1 (a,b) VALUES(2,DEFAULT); // 명시적으로 DEFAULT를 지정해 INSERT 17. 삭제하기 DELETEDELETE FROM..