首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >创建带有条件的MySQL查询

创建带有条件的MySQL查询
EN

Stack Overflow用户
提问于 2014-09-24 11:46:09
回答 1查看 14K关注 0票数 0

我是PHP & MySQL新手,我试图使用php来创建MySQL查询,下面是代码的当前状态,它仍然是WIP,但是if/结构已经给出了所需的输出,该输出随数据输入而变化,例如,可以如下所示

代码语言:javascript
复制
"SELECT * FROM tuntikortti WHERE PVM BETWEEN '2014-09-11' AND '2014-09-27' AND Henkilo =
 'Van' AND Tyonumero = '123456' AND Toiminto = '123';"

我已经确认查询行本身在MySQL中工作,但我需要在MySQL_query($con,这里的查询)中找到它。

那么,如何获得在变量或类似的变量中构建的整个if/elseif查询行的php输出呢?

代码语言:javascript
复制
<?php
include("db_connect.php");

$pvm1       = $_POST['pvm1'];
$pvm2       = $_POST['pvm2'];
$henkilo    = $_POST['henkilo'];
$tyonumero  = $_POST['tyonumero'];
$toiminto   = $_POST['toiminto'];

/* MySQL query line build, beginning */
ECHO "SELECT * FROM tuntikortti WHERE ";

    /* PVM */
    if(!empty($pvm1) && !empty($pvm2)){
        echo "PVM BETWEEN '". $pvm1 ."' AND '". $pvm2 ."'";
    } elseif(!empty($pvm1)) {
        echo "PVM = '". $pvm1 ."'";
    };

    /* Henkilo */
    if(!empty($henkilo) && !empty($pvm1)){
        echo " AND Henkilo = '". $henkilo ."'";
    } elseif(!empty($henkilo)) {
        echo " Henkilo = '". $henkilo ."'";
    };

    /* Tyonumero */
    if(!empty($tyonumero) && (!empty($pvm1) || !empty($henkilo))){
            echo " AND Tyonumero = '". $tyonumero ."'";
        } elseif(!empty($tyonumero)) {
            echo " Tyonumero = '". $tyonumero ."'";
        };

    /* Toiminto */
    if(!empty($toiminto) && (!empty($tyonumero) || !empty($pvm1) || !empty($henkilo))){
        echo "  AND Toiminto = '". $toiminto ."'";
    } elseif(!empty($toiminto)) {
            echo " Toiminto = '". $toiminto ."'";
        };

    echo ";";

    $query = mysqli_query($sql,$con);

echo "<table border='1'>
<tr>
<th>TID</th>
<th>PVM</th>
<th>Henkilo</th>
<th>Työnumero</th>
<th>Toiminto</th>
<th>Tunnit</th>
<th>Selite</th>
</tr>";

while($row = mysqli_fetch_array($query)) {
  echo "<tr>";
  echo "<td>" . $row['TID'] . "</td>";
  echo "<td>" . $row['PVM'] . "</td>";
  echo "<td>" . $row['Henkilo'] . "</td>";
  echo "<td>" . $row['Tyonumero'] . "</td>";
  echo "<td>" . $row['Toiminto'] . "</td>";
  echo "<td>" . $row['Tunnit'] . "</td>";
  echo "<td class='selitetyyli'>" . $row['Selite'] . "</td>";
  echo "</tr>";
}

echo "</table>";

include("db_close_connection.php");
    ?>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-24 12:07:02

检查此示例并尝试修改代码,

代码语言:javascript
复制
$sql = '';
$sql = "SELECT * FROM tablename WHERE ";
if(condition){
    $sql.= "fieldname = 'value'";
} elseif(condition) {
    $sql.= "fieldname = 'value'";
};

$sql.= ";";
$query = mysqli_query($con,$sql);
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26016108

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档