php time相差12小时_优化你的PHP代码,从现在做起
前言
今天我们不聊工具、规范等等等等的辅助,就聊一下该如何写一段“好”的代码,本文以我的职业生涯碰到的代码为例,如有出入请在评论区提出异议,谢谢。
搜索功能
搜索很常见,复杂的搜索大多出行在后台,举个栗子,大概需求是这样的
工作十二年准备的PHP进阶架构资料,如果你觉得有用,俺分享给大家
这是一个后台用户列表的搜索功能
初学者代码
看到这些例子你是否不由的一颤,又要开始造轮子的是不是? 以原生的例子为例,开始你可能会这样写(以下为伪代码)
if (IS_POST) { $like = ''; if (isset($_POST['username'])) { $username = $_POST['username']; $like .= "username like '%" . $username . "%' and "; } if (isset($_POST['phone'])) { $phone = $_POST['phone']; $like .= "phone like '%" . $phone . "%' and"; } if ($_POST['is_auth']) { $isAuth = $_POST['is_auth']; $like .= "is_auth like '%" . $isAuth . "%' and"; } if ($_POST['sex']) { $sex = $_POST['sex']; $like .= "sex like '%" . $sex . "%' and"; } if ($_POST['time']) { $time = $_POST['time']; $like .= "time like '%" . $time . "%' and"; } if ($_POST['wallet']) { $wallet = $_POST['wallet']; $like .= "wallet like '%" . $wallet . "%' and"; } $like = rtrim($like, 'and'); $sql = "SELECT * FROM `user` WHERE {$like}";} else { return view('user');}
封装
恩...,还不错,结构清晰,传统的初学者条型代码,接下来我们先封装一下几块代码。
function post($param){ return isset($_POST[$param]) ? $_POST[$param] : null;}if (IS_POST) { $like = ''; if (post('username')) { $username = post('username'); $like .= "username like '%" . $username . "%' and "; } if (post('phone')) { $phone = post('phone'); $like .= "phone like '%" . $phone . "%' and"; } if (post('is_auth')) { $isAuth = post('is_auth'); $like .= "is_auth like '%" . $isAuth . "%' and"; } if (post('sex')) { $sex = post('sex'); $like .= "sex like '%" . $sex . "%' and"; } if (post('time')) { $time = post('time'); $like .= "time like '%" . $time . "%' and"; } if (post('wallet')) { $wallet = post('wallet'); $like .= "wallet like '%" . $wallet . "%' and"; } $like = rtrim($like, 'and'); $sql = "SELECT * FROM `user` WHERE {$like}";} else { return view('user');}
适当使用迭代
恩,至少我们可以自由控制post方法了,但是这类过程化代码维护性太低,我们再改进下
function post($param){ return isset($_POST[$param]) ? $_POST[$param] : false;}function postAll(){ return $_POST;}if (IS_POST) { $like = ''; foreach (postAll() as $key => $value) { if (post($key)) { $like .= "{$key} like '%{$value}%' and"; } } $like = rtrim($like, 'and'); $sql = "SELECT * FROM `user` WHERE {$like}";} else { return view('user');}
面向对象
加个迭代代码看起来还算是整洁了点,作为PHP程序员,写代码不面向对象不靠谱,把class加上
function request($param = null){ return new Request($param);}class Request{ public function __construct(string $param = null) { return isset($_POST[$param]) ? $_POST[$param] : false; } public function all() { return $_POST; }}class User{ public function index() { if (IS_POST) { $like = ''; foreach (request()->all() as $key => $value) { if (request($key)) { $like .= "{$key} like '%{$value}%' and"; } } $like = rtrim($like, 'and'); $sql = "SELECT * FROM `user` WHERE {$like}"; } else { return view('user'); } }}
对User的改造
我们在对User的类进行改造,做一些判断及筛选
function request($param = null){ return new Request($param);}class Request{ public function __construct(string $param = null) { return isset($_POST[$param]) ? $_POST[$param] : false; } public function all() { return $_POST; }}class User{ public $request = [ 'username', 'phone', 'is_auth', 'sex', 'time', 'wallet' ]; public function index() { if (IS_POST) { $like = ''; foreach (request()->all() as $key => $value) { if (in_array($key, $this->request) && request($key)) { $like .= sprintf("%s like %s and", $key, $value); } } $like = rtrim($like, 'and'); $sql = "SELECT * FROM `user` WHERE {$like}"; } else { return view('user'); } }}
这就差不多了,对比真是的代码可能还相差甚远,我写这篇文章的目的不是教会你如何写代码,是想说明编码不是一次性的,应经过多次修改,使代码具有可维护性,扩展性等等的,各种“性”。
以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以点击此处查看详细资料
喜欢我的文章就关注我吧,持续更新中.....
php time相差12小时_优化你的PHP代码,从现在做起相关推荐
- MySQL插入数据与系统时间相差12小时
MySQL插入数据与系统时间相差12小时 serverTimezone改成Asia/Shanghai和GMT%2B8都不行 怎么解决!!
- centos服务器 java 项目new Date()相差12小时
环境:centos 7.x 项目语言:java 项目中使用 new Date()方法发现取值时间与当前时间相差12个小时左右,第一反应是服务器的时间不正确.在服务器调用命令 date [root@lo ...
- php time相差12小时_PHP获取时间比实际时间少8小时的问题
有两方法 1.我们写PHP程序在获取时间时,人为加上8小时(这种方法是最实用也是最土的方法) 2.如果直接获取正确时间,也可修改PHP的配置文件,即查找php.ini文件 修改方法:在php.ini文 ...
- serv-u 用户时间显示相差8小时_调好闹钟!4月8日凌晨,将迎来今年最大满月
天文预报显示,4月8日凌晨,今年第二次"超级月亮"将现身夜空,这是人们今年最佳的一次赏月良机. 据介绍,4月8日的"超级月亮"是继3月10日之后,今年的第二次& ...
- MySQL数据库时间和jdbc查询时间相差12小时问题解决
问题: 数据库所在操作系统时间正常(date命令),使用"select now() from dual;"在数据库管理工具查询,显示时间亦正常(与当前时间一致),但是通过jdbc查 ...
- php 获取当前时间相差12小时_php时间戳转换差8小时问题
PHP时间大的来分有两种,一是时间戳类型(1228348800),二是正常日期格式(2008-12-4) 所以存到数据库也有两种形式了(真正不止,我的应用就两种),时间戳类型我是保存为字符串的,这个是 ...
- php time相差12小时_PHP服务器时间差8小时解决方案
来源:http://my.oschina.net/jackguo/blog/126721 ---------------------------------- date('Y-m-d H:i:s') ...
- mongodb时间范围查询少8个小时_为何要对开源mongodb数据库内核做二次开发
关于作者 前滴滴出行技术专家,现任OPPO文档数据库mongodb负责人,负责oppo千万级峰值TPS/十万亿级数据量文档数据库mongodb内核研发及运维工作,一直专注于分布式缓存.高性能服务端.数 ...
- 1小时赚300块,不打代码帮人做个吃鸡网页 [IVX实战第3篇]
作者简介 作者名:1_bit 简介:CSDN博客专家,2020年博客之星TOP5,蓝桥签约作者.15-16年曾在网上直播,带领一批程序小白走上程序员之路.欢迎各位小白加我咨询我相关信息,迷茫的你会找到 ...
最新文章
- 细化 Sobel 边缘提取
- linux 占用缓存前10_Linux 中的零拷贝技术
- 汇编环境搭建(vs2010(2012)+masm32)
- spring8: di依赖注入--构造注入
- 0119吧 iPhone 屏幕尺寸
- python如何安装scrapy_Python爬虫之Scrapy的安装
- 关于python的if条件语句,whilefor循环等的简单说。
- CCNA-第八篇-OSPF-上
- Linux进程全解5——父子进程对文件的操作
- LeetCode 576. 出界的路径数(动态规划)
- 检查各计算机所属工作组ip,如何在Win8.1/RT 8.1中添加语言或键盘
- 如何在Redhat 7 Linux系统上停止/启动和禁用/启用防火墙
- 单应性矩阵的相关理解
- DrawIndexedPrimitiveUP这个函数
- 淘宝/天猫/京东/抖音直播年货节抢购秒杀助手更新下载,喵惠抢购助手支持自动免密支付,分享源码共同学习探讨
- mysql or 索引失效_MySQL索引失效的几种情况详析
- LimeSDR-USB硬件部分详细解读
- 智能电视硬件架构设计——整机研发
- Android图像处理之GPUImage for Android
- 2018年android常用的框架介绍
热门文章
- python分类器鸢尾花怎么写_python机器学习基础教程-鸢尾花分类
- 江南大学人工智能与计算机学院拟录取名单,江南大学人工智能与计算机学院关于接收2021级硕士研究生调剂的通知...
- MySQL · 最佳实践 · 什么时候该升级内存规格
- tar从压缩包里解压出指定文件
- IDEA下用freemarker热更新的问题
- 【转】无法将notepad++添加到打开方式列表中的解决办法
- 使用autoconf完成编译配置
- Keypress - 捕获键盘输入的JavaScript库
- go package学习——os
- 新僵尸病毒猖獗 Facebook成攻击目标