설문조사 시스템의 조건부 질문에 대한 데이터베이스 스키마
설문조사, 질문, 답변 및 PossibleAnswers에 대한 테이블로 구성된 제공된 데이터베이스 스키마 , 간단한 설문 조사 시스템의 필요성을 해결합니다. 다만, 조건문을 포함시키기 위해서는 추가적인 고려사항이 필요합니다.
조건부 로직 소개
조건부 질문 지원의 핵심은 데이터세트를 연결하여 질문 간의 관계를 파악하는 데 있습니다. 그리고 각자의 대답. 추가 테이블 QuestionDependency를 도입하여 이러한 종속성을 정의할 수 있습니다.
QuestionDependency 테이블
QuestionDependency 테이블은 특정 질문을 표시하기 위한 전제 조건을 설정합니다. . 여기에는 다음 열이 포함됩니다.
예:
"가장 좋아하는 담배는 무엇입니까?"라는 질문의 예를 생각해 보세요. 브랜드?" (질문 B)는 "담배를 사십니까?"에 "예"라고 대답한 개인에게만 표시되어야 합니다. (질문 A). QuestionDependency 테이블에는 다음 항목이 있습니다.
DependentQuestionID | PrerequisiteQuestionID | PrerequisiteAnswerID |
---|---|---|
2 | 1 | 1 |
조건부 논리에 대한 데이터베이스 쿼리
조건부 논리를 구현하려면 설문조사 시스템에서 QuestionDependency를 쿼리해야 합니다. 사용자의 이전 답변을 기반으로 어떤 질문을 표시할지 결정하는 테이블입니다. 이는 다음과 같은 쿼리를 사용하여 수행할 수 있습니다.
SELECT QuestionID FROM Question WHERE QuestionID NOT IN ( SELECT DependentQuestionID FROM QuestionDependency WHERE PrerequisiteQuestionID = 1 AND PrerequisiteAnswerID = 2 )
이 쿼리는 질문 A에 "아니요"라고 답한 사용자에게 숨겨야 하는 질문에 대한 질문 ID 목록을 반환합니다.
QuestionDependency 테이블을 통합하고 적절한 데이터베이스 쿼리를 구현함으로써 제안된 스키마는 설문조사 시스템에서 조건부 질문을 지원하는 유연하고 효과적인 방법을 제공합니다.
위 내용은 데이터베이스 스키마가 설문 조사 시스템에서 조건부 질문을 어떻게 효과적으로 처리할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!