> 데이터 베이스 > MySQL 튜토리얼 > 데이터베이스 스키마가 설문 조사 시스템에서 조건부 질문을 어떻게 효과적으로 처리할 수 있습니까?

데이터베이스 스키마가 설문 조사 시스템에서 조건부 질문을 어떻게 효과적으로 처리할 수 있습니까?

Barbara Streisand
풀어 주다: 2025-01-06 15:43:47
원래의
654명이 탐색했습니다.

How Can a Database Schema Effectively Handle Conditional Questions in a Survey System?

설문조사 시스템의 조건부 질문에 대한 데이터베이스 스키마

설문조사, 질문, 답변 및 PossibleAnswers에 대한 테이블로 구성된 제공된 데이터베이스 스키마 , 간단한 설문 조사 시스템의 필요성을 해결합니다. 다만, 조건문을 포함시키기 위해서는 추가적인 고려사항이 필요합니다.

조건부 로직 소개

조건부 질문 지원의 핵심은 데이터세트를 연결하여 질문 간의 관계를 파악하는 데 있습니다. 그리고 각자의 대답. 추가 테이블 QuestionDependency를 도입하여 이러한 종속성을 정의할 수 있습니다.

QuestionDependency 테이블

QuestionDependency 테이블은 특정 질문을 표시하기 위한 전제 조건을 설정합니다. . 여기에는 다음 열이 포함됩니다.

  • DependentQuestionID: 이전 답변에 종속되는 질문의 ID.
  • PrerequisiteQuestionID: ID 답변이 종속 항목 표시를 트리거하는 질문 질문.
  • PrerequisiteAnswerID: 종속 질문 표시 여부를 결정하는 필수 질문에 대한 특정 답변의 ID입니다.

예:

"가장 좋아하는 담배는 무엇입니까?"라는 질문의 예를 생각해 보세요. 브랜드?" (질문 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿