MySQL

2024.05.29 MySQL기본 데이터베이스 모델링

정훈5 2024. 5. 29. 08:43

장부에 고객 방문기록과 구매 이력 남기기 시나리오

class_02.sql
0.00MB

시나리오 1

고객에 방문 기록과 방문한 사람이 어떤 상품을 구매 하였는지 기록을 남겨 보자.

시나리오 2

구매를 상태와 비 구매 상태 구분하기 --> L 자 모양으로 만들어지게 된다

시나리오 3

데이터 베이스에 고객 테이블과 구매 테이블 만들어서 불필요 공간 없애기

시나리오 4

고객 테이블에 중복 회원(중복 없애기) --> 고객 이름에 PK(기본키 설정)

시나리오 5

구매 테이블에 고객명을 추가 하기
( 배달을 해야한다고 가정하면 구매 고객이름으로 고객 테이블에 접근해서 고객에 주소나 전화번호를 알 수 있다)

시나리오 6

PK : FK 관계 만들기

중요 : 현실세계를 모델링할때 아주 많이 사용되는 설계 1: N 관계

학생 : 성적 ---> 1 : N

직원 : 급여 ---> 1 : N

시나리오 7

테이블 설계단계

 

-- 데이터 집합 생성
create database db_tenco_market;

use db_tenco_market;

-- 데이터 베이스 삭제하는 명령어
-- drop database db_denco_market;

-- 사전 기반 지식 : mysql 은 대문자, 소문자를 구별하지 않는다.
-- 단, 구분 하는 RDBMS 도 있다.

-- 테이블 설계 하기

-- 고객 테이블 생성
create table userTBL(
	userName char(3) not null primary key,
    birthYear int not null,
    addr char(2) not null,
    mobile char(12)
);

show tables;
select * from userTBL;
desc userTBL;

-- 구매 테이블 생성
create table buyTBL(
	id int not null auto_increment,
    userName char(3) not null,
    prodName char(3) not null,
    price int not null,
    amount int,
    primary key(id), -- id 를 기본키로 지정한다.
    foreign key(userName) references userTBL(userName) -- 외래키 지정방법 userTBL 테이블 안에 있는 userName을 참조한다.
);

show tables;
select * from butYBL;
desc buyTBL;

 

  1. foreign key (userName) references userTBL(userName):
    • 이 구문은 외래 키(foreign key)정의하는 데 사용됩니다.

    • 외래 키는 한 테이블의 열에 대해 다른 테이블의 열을 참조하는데 사용됩니다.
      이를 통해 테이블 간의 관계를 설정하고 데이터 무결성을 유지할 수 있습니다.

    • 예를 들어, 위의 구문은 현재 테이블의 userName 열을 외래 키로 정의하고, 이 외래 키가 userTBL 테이블의 userName 열을 참조하도록 설정합니다. 이는 현재 테이블의 userName 열이 userTBL 테이블의 userName 열에 있는 값 중 하나여야 한다는 의미입니다.
  2. auto_increment:
    • 이는 열에 대한 속성으로, 해당 열의 값자동으로 증가하도록 설정합니다.

    • 보통 이 속성은 주로 기본 키(primary key) 열에 사용되며,
      새로운 레코드가 삽입될 때마다 자동으로 값이 증가하여 고유한 식별자를 생성합니다.

    • 일반적으로 auto_increment 속성은 정수 데이터 타입에만 사용됩니다.
      대표적으로 INT나 BIGINT와 같은 정수형 데이터 타입과 함께 사용됩니다.

    • 예를 들어, id INT AUTO_INCREMENT PRIMARY KEY와 같이 정의하면 id 열은 자동으로 1씩 증가하는
      고유한 값을 가지게 됩니다. 새로운 레코드가 삽입될 때마다 자동으로 증가하는 식별자가 생성됩니다.