null을 허용하지 않는 열에 제약 조건이 있어도 값이 데이터베이스에서 오는 것인지 여부를 확인하는 것이 가장 좋습니다. 당신이 무슨 말을하는지 미리데이터가 null인지 확인
0
A
답변
4
에서
덕분에 defensive programming입니다. 나는 당신이 당신의 의견을 신뢰하지 않을 때 그것을 연습하는 것이 좋다라고 생각하는 것을 좋아합니다. 지금 DB를 신뢰할 수 있다고 생각할 수도 있습니다.하지만 미래에 열이 NULL 값을 가져야한다고 결정한다면 어떨까요? 그런 다음 코드를 변경해야합니다.
(기본 키 또는 그와 같이) 변경하지 않을 것이라고 생각하지 않는다면 나는 필요하다고 생각하지 않습니다. 언젠가 당신의 스키마를 바꾸기로 결정할 때를 대비해 미래를 시험하는 것입니다. 그 열이 NULL이 의미가있는 경우를 결코 가지지 않으면, 당신은 아마 확인할 필요가 없을 것입니다. 댓글 작성자가 말한 것처럼 NULL을 얻은 경우 DB가 엉망이된다는 점에서 더 큰 문제가 있습니다.
0
나는 비즈니스 논리에 Null을 검사하고 추가한다고 말하고 싶다. 단위 테스트 중에도 특히 유용 할 것입니다. 아마 지금은 아니지만 미래에.
0
많은 요인에 따라 다릅니다. 내 프로젝트의 많은에서
내가 데이터를 검색 한 코드에서 데이터를 처리하는 코드를 분리 것이다, 단위 테스트를 가능하게하기 위해 노력하고 (예. 데이터베이스에 대화를 통해.)내가 할 수있는 그 방법 또한 다른 소스의 데이터를 입력하여 데이터를 처리하는 코드를 재사용 할 수도 있습니다. 이 경우 논리 레이어에 대한 입력 값을 절대적으로 보호 할 것입니다.
또한 응용 프로그램은 시간이 지남에 따라 발전하므로 현재 null 값을 가져올 수 없더라도 구현 될 수 있으며 많은 오래된 코드는 갑자기 쓸모없는 항목을 가져옵니다. 다루다. 나는 개인적으로 오히려 어떤 경우에 자동으로 잘못 처리하는 것보다 빨리 실패하기를 바랄 것이다.
관련 문제
- 1. SSRS - 데이터가 null인지 확인
- 2. MySQL보기에서 데이터가 NULL인지 검사합니다.
- 3. 스크립트 # : 가져온 유형이 null인지 확인
- 4. 양식 데이터가 변경되었는지 확인
- 5. 문제가 null인지
- 6. C#에서 XmlNode가 비어 있는지 또는 null인지 확인 하시겠습니까?
- 7. 포인터에 대한 포인터에 대한 질문과 그들이 NULL인지 확인
- 8. 본문에 gzip으로 압축 된 데이터가 있는지 확인
- 9. 표시하기 전에 Crystal Report에 데이터가 없는지 확인
- 10. MySQL 테이블에 열 데이터가 있는지 확인
- 11. System.NullReferenceException! = null인지 확인하는 경우
- 12. datareader의 레코드가 NULL인지 확인합니다.
- 13. null인지 확인하는 방법은 무엇입니까?
- 14. WebScriptObject가 null인지 감지
- 15. 텍스트 필드가 null인지 검사
- 16. GQL을 사용하여 BlobProperty가 NULL인지 확인합니다.
- 17. 열이 null인지 여부 (부울 값)
- 18. 객체가 null인지 아닌지 먼저 확인해야합니까?
- 19. 속성이 람다 식에서 null인지 확인하십시오.
- 20. DataGridview 셀이 Null인지 확인하는 방법
- 21. 자바 정수가 null인지 어떻게 알 수 있습니까?
- 22. 데이터가
- 23. .. 데이터가
- 24. 지난 시간 이후로 URL의 데이터가 변경되었는지 확인 하시겠습니까?
- 25. SQL 질문 확인 null
- 26. datareader가 null인지 또는 행이 없는지 확인하십시오. ASP.NET
- 27. NSMutableArray의 인스턴스가 null인지 여부를 확인하는 방법
- 28. Asp.Net MVC3 모델 검증 문자열은 null인지,
- 29. System.Runtime.Caching을 사용하지만 검색 할 때 null인지 확인하십시오.
- 30. 배열이 비어 있는지 또는 null인지 확인하십시오.
은 소프트웨어가 얼마나 중요한지에 따라 다릅니다. 일반적으로, 아니요. 아마도 의료용 소프트웨어를 작성하고 미사일을 제어한다면 ... –
코드에서 원하는 입도 수준에 달려 있다고 생각합니다. 개인적으로 데이터베이스가 null이 아니도록 설정된 열에서 null을 허용하면 데이터베이스가 손상 될 수 있기 때문에 그렇지 않습니다. – Cyberdrew