2014-03-27 86 views
0

我再次卡在MySQL查询,我想一些帮助。与where子句和if语句的MySQL查询

我试图找到最好的方法来做到这一点。我想要做的是检查$ var ='x'并基于它运行不同的查询。代码的

部分:

if ($var1 == '0' AND $var2 != '0' AND $var3 != '0' AND $var4 != '0') { 
    echo $query = "SELECT * FROM table WHERE var1 = ''"; 
}elseif ($var1 == '1' AND $var2 != '0' AND $var3 != '0' AND $var4 != '0') { 
    echo $query = "SELECT * FROM table WHERE var1 = '1'"; 
}elseif ($var1 != '0' AND $var2 == '0' AND $var3 != '0' AND $var4 != '0') { 
    echo $query = "SELECT * FROM table WHERE var2 = ''"; 
}elseif ($var1 == '0' AND $var2 == '0' AND $var3 != '0' AND $var4 != '0') { 
    echo $query = "SELECT * FROM table WHERE var1 = '' AND var2 = ''"; 
} etc.. 

的连接有很多。有一个更好的方法吗?几乎每个变量(共7个)有3个不同的选择。我不能把var = $var WHERE子句下,因为有时当我$var = '0'意味着所有的结果,所以我甚至不把它放在那里..

这是方式的过滤脚本/代码..

这对你有意义吗? 谢谢!

+0

如果例如'$ var1 == 0'和'$ var2 == 0'发生了什么......每个单一组合都有if语句吗?如果不是的话,你可以用||(OR) – superphonic

+0

来限制它的几个语句.-“有一个if语句,对于每一个单一的组合,的确很多.. – user3465843

回答

2

我认为这可以用单个查询和不同的WHERE条件来完成。您需要先定义何时在您的WHERE子句中放入var1 = ''。你应该在你的查询中逐一找到需要varX = ''的情况。

$conds = array(); 
if ($var1 == '0' || $var2 == '0') { 
    $conds[] = "var1 = ''"; // this should be the only point where var1 is included in your query, so you need to have every possible condition in this if part 
} 
if ($var3 == '0' && $var4 != '0') { 
    $conds[] = "var3 = ''"; 
} 
// ..etc.. 
$query = "SELECT * FROM TABLE WHERE " . implode(' AND ', $conds); 
+0

像一个魅力一样工作!Tyvm! – user3465843

0

如何:

$where_parts = array(); 
if (isset($var1)) { 
    if ($var1 == 0) { $var1 = ''; } 
    $where_parts [] = "var1 = '" . $var1 . "'"; 
} 
if (isset($var2)) { 
if ($var2 == 0) { $var2 = ''; } 
    $where_parts [] = "var2 = '" . $var2 . "'"; 
} 
if (isset($var3)) { 
if ($var3 == 0) { $var3 = ''; } 
    $where_parts [] = "var3 = '" . $var3 . "'"; 
} 
if (isset($var4)) { 
if ($var4 == 0) { $var4 = ''; } 
    $where_parts [] = "var4 = '" . $var4 . "'"; 
} 

$query = "SELECT * FROM table WHERE " . implode(' AND ', $where_parts); 
+0

几乎与我选择的答案一样!Tyvm的帮助!(它似乎是完全一样的东西,但你的方式有一些额外的行哈哈) – user3465843

0

是否有可能让你只专注于变量是相关的查询?例如:

$str = ""; 

# When will "var1" be in the query 
switch($var1) { 
    case '0' : $str .= " AND $var1=''"; break; 
    case '1' : $str .= " AND $var1='1'"; break; 
} 

# When will "var2" be in the query 
switch($var2) { 
    case '0' : $str .= " AND $var2=''"; break; 
    case '1' : $str .= " AND $var2='1'"; break; 
} 

... 

# If not empty then remove the first " AND " 
if(!empty($str)) { 
    $str = substr($str,4); 
} 

# Final query is a lot of concatenated strings 
$query = "SELECT * FROM table WHERE $str"; 

它可能不是代码最优化的,但它很容易理解。

+0

谢谢你的帮助队友,但它似乎有点复杂,比我其他答案 – user3465843