封装MySQL操作时Where条件语句的组织

2024-09-08 14:38

本文主要是介绍封装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条件语句的组织的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1148387

相关文章

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行