有如下图的数据表信息,有什么好的方法把它们组合成一条SQL?如果全是and 的或者全是or的,这方法好办,可是两个同时都有的,怎么办呢?全是AND 或OR的话
$sql = "select * from sk_cvfilter where cvid=58 and columnname!=''";
$query = mysql_query($sql);
$sql = '';
while($row = mysql_fetch_assoc($query)){
if($row['comparator']=='eq'){$comparator="=";}
else{$comparator=$row['comparator'];}
$sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
}
$sql = "select * from sk_cvfilter where cvid=58 and columnname!=''";
$query = mysql_query($sql);
$sql = '';
while($row = mysql_fetch_assoc($query)){
if($row['comparator']=='eq'){$comparator="=";}
else{$comparator=$row['comparator'];}
$sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
}
解决方案 »
- 谁知道怎么用javascript动态显示数据
- php 读出mysql以后生成excel中文乱码问题求教
- PHP里有没有像htmlspecialchars()那样的把要用在LIKE中的字符串中的通配符转换成转义字符的函数?
- php生成xml文件的问题
- php表单提交,更新一字段多字符
- 批量生成HTML,,在程序中分开单个生成,输出,,用到一段<srcript></script>吧,在线,急,(
- 如果把数据库里的日期字段,转成 PHP 的字符串。
- 请教诸位高手 怎么做这段程序???
- extension_dir =e:\server\php\extensions\的怪事
- 有那位有好的办法来显示在线用户?
- -> 这个符号在php编程中代表什么呢?
- PHP高手请进。把一个三维数组里的所有二维数组取出来比较,取交集
a eq 1 or
b eq 2 and
c eq 3 这个时候问题出现了,假如你不知道上面的那个关系式(a = 1 or (b=2 and b=3)),
如果只从结构看的话,你是认为(a = 1 or b =2 ) and b = 3还是 a = 1 or (b=2 and b=3)上述问题不考虑,所有or为一个条件和其他条件and的写法<?php$sql = "select * from sk_cvfilter where cvid=58 and columnname!=''";
$query = mysql_query($sql);
$sql = '';// 记录上一句的是不是or
$is_last_or = false;
while($row = mysql_fetch_assoc($query)){
if($row['comparator']=='eq'){$comparator="=";}
else{$comparator=$row['comparator'];}
if($is_last_or) {
if($row['andor'] == 'and') {
// 和下一句是and关系说明括号要结束了
$sql .=$row['columnname'].$comparator."'".$row['value']."' ) ".$row['andor'].' ';
} else {
// 持续括号里的内容
$sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
}
} elseif($row['andor'] == 'or') {
// 如果有or则意味着和下一句有或的关系(因为你这里没有括号)
$is_last_or = true;
// 加上括号吧
$sql .= '( ' . $row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
} else {
$sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
}
}
<?php$sql = "select * from sk_cvfilter where cvid=58 and columnname!=''";
$query = mysql_query($sql);
$sql = '';// 记录上一句的是不是or
$is_last_or = false;
while($row = mysql_fetch_assoc($query)){
if($row['comparator']=='eq'){$comparator="=";}
else{$comparator=$row['comparator'];}
if($is_last_or) {
if($row['andor'] != 'or') {
// 和下一句是and或者结束了关系说明括号要结束了
$sql .=$row['columnname'].$comparator."'".$row['value']."' ) ".$row['andor'].' ';
} else {
// 持续括号里的内容
$sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
}
} elseif($row['andor'] == 'or') {
// 如果有or则意味着和下一句有或的关系(因为你这里没有括号)
$is_last_or = true;
// 加上括号吧
$sql .= '( ' . $row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
} else {
$sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' ';
}
}