본문으로 바로가기
728x90
반응형

[MySQL] 9. INSERT 구문과 제약 사항

1. INSERT 구문

2. Default 제약

3. AUTO_INCREMENT

 

*사전 기반 지식 : 언더바(_)를 연결어로 사용하는 표기법을, 뱀의 꼬리를 닮았다 하여 스네이크 케이스라고 불린다.


1. INSERT 구문

-아래의 코드와 같이, insert(테이블에 데이터 삽입) 구문은 다양한 형식으로 작성할 수 있다.

 

-insert int 테이블명(컬럼1, 컬럼2, 컬럼3....)

values (값1, 값2, 값3...)

 

-insert int 테이블명 values(값1, 값2, 값3...)

 


2. Default 제약

 Default 제약은 값이 들어가지 않았을 때를 상정해, 레코드들의 기본값을 설정해준다.

 

아래의 코드를 살펴보자.

student라는 테이블 내의 major라는 열의 default가 '미정'이라고 설정되어 있다.

 

major를 '컴퓨터공학과'라고 설정한 레코드는 major='컴퓨터 공학과'로 설정된 것을 확인할 수 있다.

반면 major 값을 입력하지 않은 '김철수' 라는 레코드는 major가 '미정'으로 설정되어 있다.

이는 major 열의 default값이 '미정'이며, '김철수'가 insert될 때 major값이 입력되지 않았기 때문이다.

 

해당 항목을 default로 입력해도 '미정'으로 저장된 것을 확인할 수 있다.


3. AUTO_INCREMENT

-오토 인크리먼드(auto-increment)는 MySQL 과 같은 데이터베이스 시스템에서 자동으로 순차적인 번호를 생성해주는 기능이다. 일반적으로 테이블에서 기본키(Primary key)를 지정할 때 사용된다. 즉, 새로운 레코드를 삽입할 때마다 기본키 값이 자동으로 증가하며, 중복된 값이 입력되지 않게 해준다.


*전체 코드

-- 테이블을 삭제하는 명령
drop table employee;

-- 테이블 생성 시, DEFAULT 값을 제약 설정하는 방법
-- 사전 기반 지식: 연결어를 _(언더바)로 표기하는 법 = 스네이크 케이스

create table student(
    student_id int primary key,
    name varchar(50) not null,
    grade int not null,
    major varchar(50) default '미정' not null
);

desc student;

-- 기본 문구 모양
-- INSERT INTO 테이블명(컬럼명1, 컬럼명2 ...) VALUES(값1, 값2 ...);
-- INSERT INTO 테이블명 VALUES(값1, 값2 ...); <- 생략 버전

insert into student(student_id, name,grade,major)
values(1,'홍길동',3,'컴퓨터 공학과');

-- 디폴트 제약을 사용했을 때 값을 넣는 방법 1
insert into student(student_id, name,grade)
values(2,'김철수',4);

insert into student values(3, '이영희', 4, '경영학과');

select*from student;

-- 디폴트 제약을 사용했을 때 값을 넣는 방법 2
insert into student(student_id, name,grade,major)
values(4,'야스오',2,default);

-- delete from 구문을 사용할 때는 (실무에서) 반드시 필터를 걸자.
delete from student;

-- date 타입 형식을 사용할 때 연습

drop table `order`;

create table `order`(
    id int primary key,
    customer_order varchar(50),
    product_name varchar(20) not null,
    quantity int not null,
    order_date date not null
);

insert into `order` values(1,'빠른배송바람','신라면',2,'2024-05-30');
insert into `order` values(2,'느린배송바람','신라면',3,'2024-05-30');

-- 오류가 되는 상황 보기
insert into `order` values(3,'아주느린배송','신라면',4,'2024530');
insert into `order` values(4,'너무느린배송','신라면',4,'20241330');

desc `order`;
select*from `order`;
728x90
반응형