根据可能来自多个表的字段值对 MySQL 中的结果集进行排序的最佳方法是什么?
为简单起见,假设数据库中有四个表。主表包含许多字段,但特别是它包含具有另一个表的名称的列和该表中记录的外键。三个外部表中的每一个都包含一个名称列,我想在主表中对结果进行排序。
Example primary table:
+----+---------------+------------+-------------+
| id | foreign_table | foreign_id | more_fields |
+----+---------------+------------+-------------+
|  1 | students      |       9182 | blah, blah  |
|  2 | students      |       1008 | blah, blah  |
|  3 | parents       |       3827 | blah, blah  |
|  4 | teachers      |       4523 | blah, blah  | 
|  5 | teachers      |       1092 | blah, blah  | 
+----+---------------+------------+-------------+
Example foreign (students) table:
+-------+--------------+-------------+
| id    | name         | more_fields |
+-------+--------------+-------------+
|  9182 | Joe          |  blah, blah | 
|  1008 | Sally        |  blah, blah | 
+-------+--------------+-------------+
这在 MySQL 中可能吗?或者我是否需要遍历 PHP 中的结果并创建一个数组进行排序,然后使用类似 array_multisort() 的东西?如果使用数组,循环数千行只是为了对结果进行排序是否有效?
任何帮助是极大的赞赏。