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@yalco.kr
메일 제목 (반드시 아래 제목을 붙여넣어주세요!)
[질문] MySQL 3-2
🛑질문 전 필독!!
구글링을 먼저 해 주세요. 들어오는 질문의 절반 이상은 구글에 검색해 보면 1분 이내로 답을 찾을 수 있는 내용들입니다.
오류 메시지가 있을 경우 이를 구글에 복붙해서 검색해보면 대부분 짧은 시간 내 해결방법을 찾을 수 있습니다.
강의 페이지에 추가사항 등 놓친 부분이 없는지 확인해주세요. 자주 들어오는 질문은 페이지에 추가사항으로 업데이트됩니다.
"유료파트의 강의페이지는 어디 있나요?" - 각 영상의 시작부분 검은 화면마다 해당 챕터의 강의페이지 링크가 있습니다.
질문을 보내주실 때는 문제가 어떻게 발생했고 어떤 상황인지 등을 구체적으로 적어주세요. 스크린샷을 첨부해주시면 더욱 좋습니다.