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

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

안녕하세요?

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

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이어야 할 필드를 따로 테이블을 분리하는게 맞을 것 같기도 하구요.

게시글 목록

번호 제목
16046
16039
24343
30035
16035
16033
16031
3896
30030
3892
16029
16026
16024
16020
16016
16013
16010
3889
30027
16009
16008
16007
16005
30025
16001
15998
3886
30022
3883
15995
15992
30020
15991
15989
15980
15977
3878
15976
3871
26248
3868
3861
15972
15970
15967
15964
15954
26245
15953
15952
15948
15947
30016
15944
15943
15942
15940
15938
15935
24342
3855
15933
15930
3850
15928
15925
30013
30012
15922
15921
15918
3843
3842
15915
15912
15911
3840
15904
26244
26243
3835
15902
26239
15898
3828
26230
15897
26227
3826
26219
15893
15886
3807
3800
3796
15885
15881
15879
15877
15864