我有一个只有几个表的数据库,这些表是根据通过不断变化的表单内容提交的值填充的,这些表单内容包含很多复选框、单选、选择列表变量等......
表单的每个元素都附加了一个唯一的 ID,例如 Q1、Q2、Q3 等......无论用户在信息上核对什么,都会将其添加到数据库中。
插入信息的“提交”表如下所示:
doc_id ques ans other final
1 Q1 1 blah 1
1 Q2 5 1
1 Q2 6 1
3 Q3 1 blah
4 Q4 8
1 Q6 1375228800 1
如果用户想要获取 Q1 设置为 1 和 Q2 设置为 5 的所有文档,它可以工作,但是当指定日期时它不起作用。
搜索条件可以随时更改,除了尝试按时间戳过滤结果时,它大部分都可以工作,例如“ans”字段显示 Unix 时间戳“1375228800”
这是一个例子:
SELECT doc_id FROM submission
WHERE (ques IN ('Q1') AND ans IN ('1'))
AND (ques IN ('Q2') AND ans IN ('5'))
AND (ques = 'Q6' AND ans >= '0' AND ans <= '1375228800')
AND final = '1'
GROUP BY doc_id
除非添加时间戳部分,否则它可以工作......在这种情况下,Q6 的值为 1375228800。
让它发挥作用的最佳方法是什么?