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

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

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

게시글 목록

번호 제목
28213
31006
7898
7897
19935
7892
7885
31005
28209
7880
7877
7871
7865
7862
7858
7852
19933
19931
19928
19927
31003
19920
28206
19918
28200
7850
19916
28180
28165
19911
7842
7838
7830
7818
28150
19906
19905
19903
19901
19900
28145
7815
31002
7803
7799
7785
19898
7780
7779
7777
7776
7775
7758
19893
19892
19891
20850
19885
7752
7747
7738
19883
7735
28139
7734
7731
7725
7717
19879
7715
7710
19858
7709
7703
28134
28129
7694
7690
28125
7672
7660
28111
19857
19856
7658
28106
28098
7655
28095
7651
19851
7646
19850
24661
28089
7633
7623
28087
28085
7620