inflearn logo
강의

Course

Instructor

Young-han Kim's Introduction to Practical Databases - SQL First Steps for All IT Professionals (Step-by-Step from SQL)

DDL - Table Creation1

NOT NULL과 DEFAULT 조건의 사용법

105

ejkds602776

1 asked

0

강의에서 stock_quantity 칼럼의 제약 조건으로 다음과 같은 구문을 작성하였는데,

stock_quantity INT NOT NULL DEFAULT 0

해당 구문에서 NOT NULL 제약조건을 두지 않더라도 DEFAULT 0만 작성하여도 충분히 해당 칼럼이 NULL값이 되는 걸 방지할 수 있으리라 생각이 되어서요. NOT NULL 제약조건을 반드시 작성해야하는 걸까요? 아니면 개발자의 코드 작성 의도를 더 명확히 하고자 작성하는 걸까요?

sql mysql dbms/rdbms SQLD

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 강민정님.

질문하신 내용에 대해 설명드리겠습니다.

NOT NULLDEFAULT 제약 조건은 데이터베이스에서 각기 다른 역할을 수행합니다:

  1. NOT NULL: 이 제약 조건은 해당 칼럼에 NULL 값을 저장할 수 없음을 명시적으로 규정합니다. 즉, 데이터 삽입 시 반드시 값이 있어야 함을 보장합니다.

  2. DEFAULT: 이 제약 조건은 새로운 행이 추가될 때 칼럼에 별도의 값이 지정되지 않았을 경우, 기본값을 설정하게 됩니다.

두 제약 조건은 함께 사용되는 경우가 많습니다. NOT NULL을 사용하면, 칼럼에 NULL 부분을 철저히 방지할 수 있으며, DEFAULT 0을 지정함으로써 값을 명시적으로 제공하지 않을 때 자동으로 0으로 설정되도록 합니다. 이러한 조합은 데이터 무결성을 강화하고 의도를 명확히 하려는 목적에 매우 효과적입니다.

관련 질문이 있습니다: notnull을 붙여야하는 이유

이 질문에서도 사용자가 nullable = false를 사용하는 이유에 대해 궁금해 했습니다. 다른 개발자가 추가로 코드를 수정하거나, 테이블 정의를 참고할 때 불필요한 혼선이 없도록 하기 위해 의도를 명확히 하는 것이 중요합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

교재 p.31 실행순서 오류?

0

108

2

sql서버가 켜지면 다시 꺼짐

0

108

2

INSERT INTO 관련 질문

0

86

1

MySQL 설치 질문 드립니다.

0

144

2

mysql화면 오류

0

90

1

mysql 버전

0

94

1

정말 별 거 아니긴 한데요

0

135

2

논리적 실행 순서에서 SELECT 설명 질문

0

87

2

primary key는 테이블 당 하나만 존재할 수 있다?

0

109

1

노트앱 어떤 거 쓰시나요?

0

145

1

drop과 truncate

0

87

1

db 공부관련 질문

0

128

2

GROUP BY 에서 ORDER BY 를 사용했을 때 오류

0

114

1

오타 제보

0

82

1

7.SQL - 집계와 그룹핑 : 문제와 풀이에서 2번문제

0

67

1

GROUP BY 강의 중 ORDER BY에 관한 질문

0

91

1

문제5번 - 함수 코드 중복 방지를 위한 방법 중 서브쿼리와 CTE의 차이

0

120

1

order 테이블 생성이 안되네요

0

121

4

ifnull()과 default 차이

0

95

1

help me 도와주세요 MySQL 설치 pls 급해요

0

149

2

DB 설계편 예상 출시일

0

154

2

강의 내용

0

106

1

오류 원인

1

101

3

개발자 취준

0

244

2