테스트 사이트 - 개발 중인 베타 버전입니다

꼭 NOT NULL 이 아니라 NULL로 지정해야 하는 경우

· 13년 전 · 982 · 3
안녕하세요?

인터넷을 아무리 검색해 봐도

NOT NULL 이 아니라 NULL로 지정하는 경우에 대해서

정리한 곳이 없어서 궁금합니다.

NULL로 꼭 써야 하는 경우는 어떤경우가 있을까요?

NOT NULL로 지정하면, 속도가 빨라지고 용량도 1bit 줄어듭니다.

PHP + javascript+ mysql 에서 NULL로 반드시 써야 하는 경우는 어떤경우가 있을까요?

그냥 무조건 NOT NULL로 지정하면 될까요?

php 상으로는 0이나 문자형 '' 의 경우 if ($a) 에서  false 체크가 잘 되니 굳이 NULL을 쓰지 않아도 될까요

일반적인 경우에 어떻게 하는 것이 좋은지 팁좀 부탁드립니다.

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 3개

테이블에 컬럼이 많이 있는데, insert시 전체를 입력해야 할 필요가 없는 경우 primary key에 대해서만 not null 처리를 하고 나머지 컬럼들은 null로 설정해 놓지 않나요?
네 지금 어떤 프로젝트를 맡고 있는데,
2006년에 작업 분이 모두 그렇게 되어있었습니다.
그런데 SQL튜닝에 대해서 뒤져보니까 되도록 NOT NULL로 할수 있는 곳은 모두 NOT NULL로 하라고 하라고 합니다.

문제는 NOT NULL로 사용하면 안되고, NULL로 사용해야 되는 경우가 있는가 입니다

insert 시 전체를 입력해야 할 필요가 있는 경우에도, 굳이 NULL로 정해야 할 필요가 있나요? 오류검색 때문인가요? 기본값0 으로 주고 NOT NULL로 하거나, ""로 오류검출하면 안될까요
가능하면 NOT NULL로 사용하는게 좋지 않을까 싶네요. 만약 NOT NULL이 필요하다면, NOT NULL이어야 할 필드를 따로 테이블을 분리하는게 맞을 것 같기도 하구요.

게시글 목록

번호 제목
20097
20095
20093
20092
20091
20089
20086
20085
20084
20083
20082
28358
20081
20079
20078
20077
20076
20075
20074
20073
20072
20071
20070
20069
8148
20057
8141
24669
20056
8138
28353
20055
20054
20053
20052
20051
20050
20047
20046
20045
20044
8111
20043
20042
20040
20039
20037
20036
20035
20027
8107
31022
20026
20025
20024
20023
28350
20022
20018
20017
8099
20016
20013
8090
20012
20010
20009
19998
28348
28347
19997
19996
19995
19993
8087
8065
19990
8063
8056
19989
19988
19987
19986
19985
19984
19983
19982
8054
19981
19980
19979
19978
19977
19976
19975
19974
19973
19972
19971
19970