🏠 MySQL
Section 3. 데이터 조작하기
Lesson 2. 테이블 만들고 데이터 입력하기

1. 테이블 생성/수정/삭제

CREATE TABLE - 테이블 만들기

CREATE TABLE people ( person_id INT, person_name VARCHAR(10), age TINYINT, birthday DATE );

ALTER TABLE - 테이블 변경

-- 테이블명 변경 ALTER TABLE people RENAME TO friends, -- 컬럼 자료형 변경 CHANGE COLUMN person_id person_id TINYINT, -- 컬럼명 변경 CHANGE COLUMN person_name person_nickname VARCHAR(10), -- 컬럼 삭제 DROP COLUMN birthday, -- 컬럼 추가 ADD COLUMN is_married TINYINT AFTER age;

DROP TABLE - 테이블 삭제

DROP TABLE friends;



2. INSERT INTO - 데이터 삽입

INSERT INTO people (person_id, person_name, age, birthday) VALUES (1, '홍길동', 21, '2000-01-31'); -- 모든 컬럼에 값 넣을 때는 컬럼명들 생략 가능 INSERT INTO people VALUES (2, '전우치', 18, '2003-05-12'); -- 일부 컬럼에만 값 넣기 가능 (NOT NULL은 생략 불가) INSERT INTO people (person_id, person_name, birthday) VALUES (3, '임꺽정', '1995-11-04'); -- 자료형에 맞지 않는 값은 오류 발생 INSERT INTO people (person_id, person_name, age, birthday) VALUES (1, '임꺽정', '스물여섯', '1995-11-04'); -- 여러 행을 한 번에 입력 가능 INSERT INTO people (person_id, person_name, age, birthday) VALUES (4, '존 스미스', 30, '1991-03-01'), (5, '루피 D. 몽키', 15, '2006-12-07'), (6, '황비홍', 24, '1997-10-30');



3. 테이블 생성시 제약 넣기

CREATE TABLE people ( person_id INT AUTO_INCREMENT PRIMARY KEY, person_name VARCHAR(10) NOT NULL, nickname VARCHAR(10) UNIQUE NOT NULL, age TINYINT UNSIGNED, is_married TINYINT DEFAULT 0 );
제약 설명
AUTO_INCREMENT 새 행 생성시마다 자동으로 1씩 증가
PRIMARY KEY 중복 입력 불가, NULL(빈 값) 불가
UNIQUE 중복 입력 불가
NOT NULL NULL(빈 값) 입력 불가
UNSIGNED (숫자일시) 양수만 가능
DEFAULT 값 입력이 없을 시 기본값

💡 PRIMARY KEY (기본키)

  • 테이블마다 하나만 가능
  • 기본적으로 인덱스 생성 (기본키 행 기준으로 빠른 검색 가능)
  • 보통 AUTO_INCREMENT와 함께 사용
  • ⭐ 각 행을 고유하게 식별 가능 - 테이블마다 하나씩 둘 것


INSERT INTO people (person_name, nickname, age) VALUES ('김철수', '아이언워터', 10); INSERT INTO people (person_name, nickname, age) VALUES ('이불가', '임파서블', -2); INSERT INTO people (person_name, nickname, age, is_married) VALUES ('박쇳물', '아이언워터', NULL, 1); -- nickname에 NULL, '아이언수' 넣어보기
🤔 얄코에게 질문하기
강의에서 이해가 안 되거나 실습상 문제가 있는 부분,
설명이 잘못되었거나 미흡한 부분을 메일로 알려주세요!

답변드린 뒤 필요할 경우 본 페이지에
관련 내용을 추가/수정하도록 하겠습니다.
이메일 주소
yalco@kakao.com
메일 제목 (반드시 아래 제목을 붙여넣어주세요!)
[질문] MySQL 3-2
🏠 MySQL