封装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 server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

浅谈mysql的not exists走不走索引

《浅谈mysql的notexists走不走索引》在MySQL中,​NOTEXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引,下面就来介绍一下mysql的notexists走不走索... 在mysql中,​NOT EXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引。以下

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach