php - 从缺少某些 WHERE 条件的表中选择

标签 php mysql sql sorting conditional-statements

我有以下sql请求

        if(isset($_GET['room'])) {

            if($_GET['status'] == 'all' && $_GET['room'] == 'all'){
                $stmt = $pdo->prepare("SELECT DISTINCT flatnetto FROM flat ORDER BY flatnetto");
                $stmt->execute(array($_GET['room'], $_GET['status']));
            }else if($_GET['status'] == 'all'){
                $stmt = $pdo->prepare("SELECT DISTINCT flatnetto FROM flat WHERE kk = ? ORDER BY flatnetto");
                $stmt->execute(array($_GET['room']));
            }else if($_GET['room'] == 'all'){
                $stmt = $pdo->prepare("SELECT DISTINCT flatnetto FROM flat WHERE sold = ? ORDER BY flatnetto");
                $stmt->execute(array($_GET['status']));
            }else{
                $stmt = $pdo->prepare("SELECT DISTINCT flatnetto FROM flat WHERE kk = ? AND sold = ? ORDER BY flatnetto");
                $stmt->execute(array($_GET['room'], $_GET['status']));
            }               

            $rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
        }

上面的代码可以只发出一个sql请求吗?我的意思是,可以只提出一个请求

    $stmt = $pdo->prepare("SELECT DISTINCT flatnetto FROM flat WHERE kk = ? AND sold = ? ORDER BY flatnetto");

但条件“kk”和“sold”可能存在也可能不存在(将具有不可排序的“all”值)。因此,例如,如果“kk”不存在,则忽略它并仅在条件“已售出”的情况下继续选择。

上面的代码可以工作,但是定义所有可能的选项非常烦人。


状态可以有值(已售出、保留、全部)

房间可以有值(1kk、2kk、3kk、全部)

值“全部”意味着例如我对 2kk 房间很感兴趣,无论是“已售出”还是“已保留”都只显示给我所有。

更新问题。

正如下面的回答所写,可以发出一个 sql 请求。但问题仍然存在,因为我们只是将“可能的选项定义”移动到 sql 查询,但我仍然必须定义所有可能的选项。我无法想象如何定义所有可能的选项,如果我们不仅有两个输入,而且例如“房间、状态、价格 1、价格 2、楼层、尺寸……”,并且所有这些都可以有自己的值(value),但也有值(value)“所有”。在这种情况下,我们必须从所有可能的变化(在这种情况下超过 20 种可能的变化)中定义所有可能的选项。我认为这不是它在更大项目中的工作方式。

最佳答案

您可以使用以下代码生成您的 SQL 查询

$param=Array();

## associate query parameters to sql column
$keys=Array("room" => "kk", "status" => "sold");

## generate parameter list
foreach ($keys as $k=>$v)
if (isset($_GET[$k])&&($_GET[$k]!='all'))
   $param[$v]=$_GET[$k];

## generate query
$query="SELECT DISTINCT flatnetto FROM flat WHERE ".
    implode(" = ? AND ", array_keys($param)).
    (count($param) ? " = ?" : "1")
    ." ORDER BY flatnetto";

## execute
$stmt = $pdo->prepare($query);
$stmt->execute($param);

关于php - 从缺少某些 WHERE 条件的表中选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29044430/

相关文章:

php - 一定时间后删除非事件用户有问题吗?

php - mysqli_num_rows 不能正常工作

mysql - Oracle 有 "all_objects"表。 MySQL中是否存在类似的大表?

php - 匹配mysql中值数组中的一个值

sql - 使用 JSON_BUILD_OBJ 从 Postgres 返回 JSON

sql - TSQL - 选择具有相同列 A 但不同列 B 的行

sql - 创建SQL Server回滚脚本的最佳方法?

php - jQuery .empty() 导致 AJAX 填充的 div 闪烁

php - 物理删除在 laravel5 中启用软删除的模型?

php - 我如何在wordpress页面上打印'bloginfo('url')'