1.关于链式查询
$post_db = D('Post');
$total = $post_db;
$total=$total->where($where1);
$total=$total->where($where2);
$list=$total->order($order)->limit($limit)->select();
$count=$total->count();
这时我们发现,$count 的值并不是我们查出来的数量,而是总量,而且表达式
$total=$total ->where($where1); 与 $total->where($where1);的效果是一样的,$total的值会改变,如果我们需要查询总数时,只能重新查询一遍,这是thinkphp里很不人性的功能;
2. php的原生函数:preg_replace()
需求:想通过preg_replace()修改文本里的特定值
最开始使用如下:(备份SQL时修改自增的起始值,为什么有这个需求呢,这牵扯到数据库备份时,备份log文件,分批备份,而此时log也一直在增加,导致自增值失配,在还原数据时有问题)
preg_replace('/AUTO_INCREMENT=(\d+)/', 'AUTO_INCREMENT='.“$1” + 2, $sql);
我们发现会被替换成 AUTO_INCREMENT= 2,而$1不被识别,
而单独使用'AUTO_INCREMENT='.“$1”,$1可以识别,
那么问题来了,看样子preg_replace() 的第二个参数如果引用了如“$1”类似的变量,变量的使用会有问题,没去查具体原因,
我的解决方法是:
if(preg_match('/AUTO_INCREMENT=(\d+)/',$sql,$matches)){
$auto_int_start = $matches[1] + (int)($count/C('DATA_BACKUP_EXPORT_LIMIT'));
}
$sql = preg_replace('/AUTO_INCREMENT=(\d+)/', 'AUTO_INCREMENT='.$auto_int_start, $sql);
那就是事先把只计算好,再替换,后面再看看具体原因吧,如果有同学知道原理,也可以留言告诉我,3Q!
版权声明:本文为博主原创文章,未经博主允许不得转载。
以上就介绍了使用thinkphp和php中的问题-preg_replace, 链式查询,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
独孤九贱(3)_JavaScript视频教程
javascript是运行在浏览器上的脚本语言,连续多年,被评为全球最受欢迎的编程语言。是前端开发必备三大法器中,最具杀伤力。如果前端开发是降龙十八掌,好么javascript就是第18掌:亢龙有悔。没有它,你的前端生涯是不完整的。《php.cn独孤九贱(3)-JavaScript视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了javascript知识。
JavaScript教程140717次播放
独孤九贱(6)_jQuery视频教程
jQuery是一个快速、简洁的JavaScript框架。设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。 核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。兼容各种主流浏览器,如IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+等,是全球最流行的前端开发框架之一。PHP中文网根据最新版本,独家录制jQuery最新视频教程,回馈PHP中文网的新老用户。
jQuery教程115593次播放
jQuery与Ajax基础与实战
jQuery是最流行的JS函数库,封装了许多实用的功能,其中最引人入胜的就是Ajax。 jQuery中的Ajax操作,语法简单,操作方便,使Ajax从未如此轻松,前端人员从此不再为与服务器异步交互而发愁,本套课程,精选了最常用的几个方法,从基本的语法到每个参数,再到具体实例进行了全面的讲解。
AJAX教程15279次播放
Git教程(60分钟全程无废话版)
Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。 Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持
JavaScript教程13411次播放