本文主要是介绍封装MySQL操作时Where条件语句的组织,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在对数据库进行封装的过程中,条件语句应该是相对难以处理的,毕竟条件语句太过于多样性。
条件语句大致分为以下几种:
1、单一条件,比如:where id = 1;
2、多个条件,相互间关系统一。比如:where id > 10 and age > 20 and score < 60;
3、多个条件,相互间关系不统一。比如:where (id > 10 OR age > 20) AND score < 60;
因为多数情况下,多个条件之间的逻辑都是AND的关系,所以我们默认如此。
条件数组构造:
$where = array('id' => array('>', 10),'age' => array('>', 20),
);
如果条件语句属于前两种,我们便可以使用上述方式,即:将条件语句中字段作为$where数组的键,将操作符(> < = in like)以及对应的值以数组的方式作为字段对应的值。
封装类中处理代码:
function whereParse($data) {$str = '';foreach ($data $key => $value) {$sign = $value[0];$where = $value[1];if($sign == 'in') {$where = implode("','", $where);$str .= "$key in ('$where') and ";} else {if(is_numeric($where)) {$str .= "$key $sign $where and ";} else {$str .= "$key $sign '$where' and ";}}}$str = substr($str, 0, -4);return $str;
}
一开始不知道第三种该如何去操作,之后借鉴了ThinkPHP框架中对于数据库的封装中对Where条件语句的操作之后,发现他们是这样做的。
使用下述SQL语句作为例子:
SELECT * FROM table WHERE (id > 10 OR age > 20) AND score < 60;
在ThinkPHP中,选择将逻辑关系为OR的两个条件放在键名为 _complex 的数组元素中。
$where['_complex'] = array('id' => array('>', 10),'age' => array('>', 20),
);
而他们之间的逻辑关系,ThinkPHP将其放在键名为 _logic
的数组元素中。
$where['_logic'] = 'OR';
而余下的逻辑关系为与的只需要用_complex元素内的方式在where中组织即可。
$where['score'] = array('<', 60);
这样当我们去处理条件语句时,首先判断条件数组中是否存在_complex
键名,如果存在,就将_complex
中的元素与_logic
中的逻辑关系进行组合,完成后,将逻辑AND的其他数据组合即可.
/*** 对条件语句进行解析*/
function whereParse($data) {if(array_key_exists('_complex', $data)) {$complex = parse($data['_complex'], $data['_logic']);}unset($data['_complex']);unset($data['_logic']);$str = parse($data) . " AND " . $complex;return $str;
}
/*** 对单一关系进行解析*/
function parse($data, $relation = '') {$str = '(';if(empty($relation)) {$relation = 'AND';}foreach ($data as $key => $value) {$sign = $value[0];$where = $value[1];if($sign == 'in') {$where = implode("','", $where);$str .= "$key in ('$where') $relation ";} else {if(is_numeric($where)) {$str .= "$key $sign $where $relation ";} else {$str .= "$key $sign '$where' $relation ";}}}$str = substr($str, 0, -4);$str .= ')';return $str;
}
然后我们调用上述函数:
echo whereParse($where);
// 输出:
(score < 60 ) AND (id > 10 OR age > 20)
其实还有一种更为复杂的条件语句,形如:(id > 10 OR age > 20) AND (score < 60 OR phone like 135%);
上述情况并未对此进行处理,之后再谈。
http://www.2liang.me/archives/216
这篇关于封装MySQL操作时Where条件语句的组织的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!