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

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

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

게시글 목록

번호 제목
28080
7612
7598
7595
19842
28079
19840
7593
28076
7590
28072
28065
19836
7586
28058
7573
31754
7552
28057
30993
28052
7546
7544
7538
7519
30992
19834
7517
7512
7511
19832
19820
7509
24658
7508
7507
19818
30990
7506
7505
7498
7492
28051
7481
30988
19813
19812
7477
7476
7471
7467
19810
7464
19809
7463
7457
30980
7450
28043
7447
7440
28040
7438
7430
7427
7423
7414
7408
7405
7401
7400
19808
7398
7393
7389
19805
7382
7379
7378
7363
7361
7356
19804
7355
7352
19786
7342
7336
7332
19783
7328
7325
7324
28036
19782
7321
26574
7314
7312
19781