封装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

相关文章

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

MySQL修改密码的四种实现方式

《MySQL修改密码的四种实现方式》文章主要介绍了如何使用命令行工具修改MySQL密码,包括使用`setpassword`命令和`mysqladmin`命令,此外,还详细描述了忘记密码时的处理方法,包... 目录mysql修改密码四种方式一、set password命令二、使用mysqladmin三、修改u

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

使用C++实现单链表的操作与实践

《使用C++实现单链表的操作与实践》在程序设计中,链表是一种常见的数据结构,特别是在动态数据管理、频繁插入和删除元素的场景中,链表相比于数组,具有更高的灵活性和高效性,尤其是在需要频繁修改数据结构的应... 目录一、单链表的基本概念二、单链表类的设计1. 节点的定义2. 链表的类定义三、单链表的操作实现四、

Python利用自带模块实现屏幕像素高效操作

《Python利用自带模块实现屏幕像素高效操作》这篇文章主要为大家详细介绍了Python如何利用自带模块实现屏幕像素高效操作,文中的示例代码讲解详,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、获取屏幕放缩比例2、获取屏幕指定坐标处像素颜色3、一个简单的使用案例4、总结1、获取屏幕放缩比例from

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查