当处理特定列中具有未知数量值的表时(例如提供的示例中的“way”),创建MySQL 中的交叉表似乎是一个挑战。传统方法需要在查询时指定列名,这在动态情况下可能不可行。
为了解决这一挑战,可以采用两种编程解决方案:
此方法涉及获取具有不确定计数的列的不同值。使用此值列表,您可以构建动态数据透视查询并将必要的列附加到 SELECT 语句中。
<code class="sql">foreach ($pdo->query("SELECT DISTINCT `way` FROM `MyTable`") as $row) { $way = (int) $row["way"]; $way_array[] = "MAX(IF(`way`=$way, `time`)) AS way_$way"; } $pivotsql = "SELECT stop, " . join(", ", $way_array) . "FROM `MyTable` GROUP BY `stop`";</code>
此替代方法涉及按数据库中的结构逐行查询数据。您将收集数组中的数据,然后将其转换为列,然后再显示。
<code class="php">$stoparray = array(); foreach ($pdo->query("SELECT * FROM `MyTable`") as $row) { $stopkey = $row["stop"]; if (!array_key_exists($stopkey, $stoparray)) { $stoparray[$stopkey] = array("stop"=>$stopkey); } $waykey = "way_" . $row["way"]; $stoparray[$stopkey][$waykey] = $row["time"]; }</code>
两种方法都需要编码以适应列数未知的动态情况。方法的选择将取决于具体的数据操作要求和效率考虑。
以上是当列值未知时如何在 MySQL 中创建动态交叉表?的详细内容。更多信息请关注PHP中文网其他相关文章!