在 PHP 中,使用 UNION 操作符可以将多个 SELECT 查询的结果组合成一个结果集。与其他查询方式相比,UNION 具有以下特点和优势:
-
结果集合并:UNION 操作符可以将多个 SELECT 查询的结果合并成一个结果集,方便进行后续处理和展示。
-
去重:默认情况下,UNION 会去除重复的行。如果你需要保留重复的行,可以使用 UNION ALL 操作符。
-
排序:UNION 操作符可以对合并后的结果集进行排序。你可以使用 ORDER BY 子句对结果集进行排序。
与其他查询方式相比,UNION 的缺点是性能可能较低,因为它需要对多个查询结果进行合并和去重操作。然而,在大多数情况下,这种性能损失是可以接受的,因为 UNION 提供了方便的结果集合并和去重功能。
以下是一个使用 UNION 的示例:
// 查询部门 A 的员工信息 $queryA = "SELECT name, age FROM departmentA"; // 查询部门 B 的员工信息 $queryB = "SELECT name, age FROM departmentB"; // 使用 UNION 将两个查询结果合并成一个结果集 $result = $queryA . " UNION " . $queryB; // 执行查询并获取结果 $result = mysqli_query($connection, $result); // 处理结果集 while ($row = mysqli_fetch_assoc($result)) { echo "Name: " . $row["name"] . ", Age: " . $row["age"] . "
"; }
总之,PHP 中的 UNION 操作符提供了一种方便的将多个 SELECT 查询结果合并的方法。虽然性能可能较低,但在大多数情况下,这种性能损失是可以接受的。