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

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

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

게시글 목록

번호 제목
8265
20403
20402
20401
20400
8259
20399
20398
8255
8249
8246
8242
20396
8240
20395
20394
31033
28385
20393
28380
20392
28377
20391
20390
20389
20388
20387
20386
20385
20384
20383
20382
8238
20380
20379
28376
28372
20378
20377
8235
20375
20374
20373
20372
20371
20370
28370
20369
28366
20368
20367
20366
20365
20364
20363
20362
20361
20360
20359
8231
20358
20357
20356
20355
20354
20353
20352
20351
20350
20349
20348
20347
20346
20345
20344
20343
20342
20341
20340
20339
20338
20337
20336
20335
20334
20333
20332
20331
20330
20329
20328
20327
20326
20325
20324
20323
20322
20321
20320
20319