gpt4 book ai didi

mysql - 单个查询从多个表收集数据

转载 作者:行者123 更新时间:2023-11-29 10:53:23 24 4
gpt4 key购买 nike

我在从我设计的 SQL 数据库收集数据时遇到问题。

这是一个包含不同类型问题的表,每种类型都有自己的表,其中包含不同的列,并且将 QuestionID 作为引用该表的外键,如下所示。

 Column   |          Type          | Modifiers
------------+------------------------+-----------
questionid | integer | not null
header | character varying(500) |
Indexes:
"quizquestion_pkey" PRIMARY KEY, btree (questionid)
Referenced by:
TABLE "matchingpairs" CONSTRAINT "matchingpairs_questionid_fkey" FOREIGN KEY (questionid) REFERENCES quizquestion(questionid)
TABLE "mcqchoices" CONSTRAINT "mcqchoices_questionid_fkey" FOREIGN KEY (questionid) REFERENCES quizquestion(questionid)
TABLE "questionsinquiz" CONSTRAINT "questionsinquiz_questionid_fkey" FOREIGN KEY (questionid) REFERENCES quizquestion(questionid)
TABLE "truefalsequestion" CONSTRAINT "truefalsequestion_questionid_fkey" FOREIGN KEY (questionid) REFERENCES quizquestion(questionid
)

我还有另一个表,它还使用问题 ID 来记录哪个问题属于哪个测验

   Column   |  Type   | Modifiers
------------+---------+-----------
quizid | integer | not null
questionid | integer | not null
index | integer |
Indexes:
"questionsinquiz_pkey" PRIMARY KEY, btree (quizid, questionid)
Foreign-key constraints:
"questionsinquiz_questionid_fkey" FOREIGN KEY (questionid) REFERENCES quizquestion(questionid)
"questionsinquiz_quizid_fkey" FOREIGN KEY (quizid) REFERENCES quiz(quizid)

有没有一种方法可以在一个查询中收集所有不同的问题,或者我是否必须对每种问题类型进行查询,或者我可以在数据库表设计中更改一些不同的内容。

最佳答案

根据您的描述,您可以使用Postgres继承。这是一个表可以相互关联的工具。开始了解它的地方是 documentation .

使用继承,您将拥有一个名为 questions 的父表,它定义 questionId 和其他相关列。然后,您可以定义多个其他表,例如从 questions 继承的 matchingPairsQuestions。然后,查询和外键可以引用各个“子”表,也可以引用所有这些表作为一个集合。

关于mysql - 单个查询从多个表收集数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43377014/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com