我是一名PHP初学者。我之前已经涉足过,但是当我开始擅长时,一个新项目将我带到了其他地方。如果有人可以协助;我很感激。
我使用多个查询和数组从两个mySQL表之间检索数据,从1个初始已知变体开始。
我希望每个查询都能处理上一个查询的所有结果。这没有发生。
当前结果:第一个查询回显了所有结果。第二个查询回应了一个结果。第三个查询回应1结果。最终的回显显示所有最终结果(需要,但缺少前148行)。
期望的结果:回显所有三个查询的所有149个结果,然后回显所有3个查询的表/数组(以确认相关性)。
<?php
// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
//Select all POST_IDs for variation 2.1M
$sql = "SELECT post_id FROM wp_postmeta WHERE meta_value = '2-1m'";
$result = $conn->query($sql);
//Array and display POST_IDs
if ($result->num_rows > 0) {
// output data of each row
while($row = $result->fetch_assoc()) {
echo "id: " . $row["post_id"]. "<br>";
}
} else {
echo "0 results";
}
//Prepare POST_IDs for next query
foreach ($result as $row){
$postids = $row["post_id"];
}
//Use POST_IDs to select all PARENT_IDs
$sql2 = "SELECT post_parent FROM wp_posts WHERE ID = ($postids)";
$result2 = $conn->query($sql2);
//Array and display PARENT_IDs
if ($result2->num_rows > 0) {
// output data of each row
while($row2 = $result2->fetch_assoc()) {
echo "parentid: " . $row2["post_parent"]. "<br>";
}
} else {
echo "0 results";
}
//Prepare PARENT_IDs for next query
foreach ($result2 as $row2){
$parentids = $row2["post_parent"];
}
//Select PRICES using PARENT_IDs and META_KEY for Price
$sql3 = "SELECT meta_value FROM wp_postmeta WHERE meta_key = '_price' AND post_id = ($parentids)";
$result3 = $conn->query($sql3);
if ($result3->num_rows > 0) {
// output data of each row
while($row3 = $result3->fetch_assoc()) {
echo "price: " . $row3["meta_value"]. "<br>";
}
} else {
echo "0 results";
}
//Array and display PRICES
foreach ($result3 as $row3){
$prices = $row3["meta_value"];
}
//Display all retrieved data
echo "<div><p>" . $postids . " " . $parentids . " " . $prices . "</p></div>";
$conn->close();
?>
答案 0 :(得分:1)
您重写了变量而不是将它们累积到数组中:
foreach ($result as $row){
$postids = $row["post_id"];
}
应该是:
$postids = [];
foreach ($result as $row){
$postids[] = $row["post_id"];
}
然后:
"WHERE ID = ($postids)"
应该是:
if (!empty($postids)) {
... "...WHERE ID IN (".implode(',', $postids).")..." ...
}
注意:您应该查看参数化查询:Parameterized Queries PHP/MySQL
同样的事情发生在$parentids
。