繁体   English   中英

如何按照唯一且预定的顺序(而不是asc或desc)对来自mysql数据库的数据进行排序

[英]How do I sort data from a mysql db according to a unique and predetermined order, NOT asc or desc

我需要向学生展示1000个测试问题,每页10个。

问题在mysql表中,答案将在另一个表中。

我需要每个学生的问题以不同于其他任何学生的预定顺序出现。 当他们注册并放置在usermeta表中时,排序顺序是预先确定的。

在usermeta表中,有一列列出了问题显示的顺序。 该列中的顺序对于每个学生而言都是唯一的,并且类似于以下示例:8 | 14 | 97 | 54 | 21 | 37 | 54 | 61 ...等。

向学生显示的第一个问题是第8个问题,然后是第14个问题,然后是第97个问题,依此类推,每页列出10个问题。

我不需要按升序或降序对问题进行排序。 另外,如果可以帮助找到解决方案,我可以更改数据库结构。

另外,如果可以帮助找到解决方案,我可以更改数据库结构。

如果可以更改数据库结构,则不要将排序顺序存储为以管道分隔的字符串,而应将其存储在单独的表中,该表将每个问题映射到给定学生应出现的顺序。

student_id, sort_order, question_id
1               1               8
1               2               2
1               3               97

然后在为特定学生选择问题时加入您的排序表。

SELECT q.* FROM 
questions q
JOIN questions_sorting_order qso
ON q.id = qso.question_id
ORDER BY qso.sort_order
WHERE qso.student_id = :student_id
SELECT * FROM ints;
+---+
| i |
+---+
| 0 |
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
| 6 |
| 7 |
| 8 |
| 9 |
+---+

SELECT i2.i*10+i1.i x
     , FIND_IN_SET(i2.i*10+i1.i,'8,14,97,54,21,37,54,61') y 
  FROM ints i1
     , ints i2
HAVING y > 0 
 ORDER 
    BY y;
+----+---+
| x  | y |
+----+---+
|  8 | 1 |
| 14 | 2 |
| 97 | 3 |
| 54 | 4 |
| 21 | 5 |
| 37 | 6 |
| 61 | 8 |
+----+---+

请注意,第二次忽略54

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM