thinkphp5.1时间查询
web ThinkPHP5.1 2019-01-11 2609 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

6415842 2611 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
<?php
namespace app\index\model;
use think\Model;
use think\Db;

class Articles extends Model {
	/**
	 * 时间查询
	 */
	public function indexFun(){
		// 使用where方法-大于某个时间
		$rs = Db::table('zht_articles')
			->where('createTime', '> time', '2016-10-1')
			->select();
		// 小于某个时间
		$rs = Db::table('zht_articles')
			->where('createTime', '< time', '2016-10-1')
			->select();
		// 时间区间查询-第三个参数可以传入任何有效的时间表达式,会自动识别你的时间字段类型,支持的时间类型包括timestamps、datetime、date和int
		$rs = Db::table('zht_articles')
			->where('createTime', 'between time', ['2015-1-1', '2017-1-1'])
			->select();
		// 使用whereTime方法-whereTime方法提供了日期和时间字段的快捷查询-大于某个时间
		$rs = Db::table('zht_articles')
			->whereTime('createTime', '>=', '2016-10-1')
			->select();
		// 可以简化
		$rs = Db::table('zht_articles')
			->whereTime('createTime', '2016-10-1')
			->select();
		// 小于某个时间
		$rs = Db::table('zht_articles')
			->whereTime('createTime', '<', '2016-10-1')
			->select();
		// 时间区间查询
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'between', ['2015-1-1', '2017-1-1'])
			->select();
		// 可以简化
		$rs = Db::table('zht_articles')
			->whereTime('createTime', ['2015-1-1', '2017-1-1'])
			->select();
		// 不在时间区间查询
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'not between', ['2015-1-1', '2017-1-1'])
			->select();
		// 针对时间的区间查询,系统还提供了一个whereBetweenTime快速方法
		// 查询2017年上半年注册的用户
		$rs = Db::table('zht_articles')
			->whereBetweenTime('createTime', '2017-01-01', '2017-06-30')
			->select();
		// 查询2017年6月1日注册的用户-没有指定结束时间的话,表示查询当天。
		$rs = Db::table('zht_articles')
			->whereBetweenTime('createTime', '2017-06-01')
			->select();
		// 时间表达式-获取今天的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'today')
			->select();
		// 时间表达式-获取昨天的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'yesterday')
			->select();
		// 时间表达式-获取本周的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'week')
			->select();
		// 时间表达式-获取上周的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'last week')
			->select();
		// 时间表达式-获取本月的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'month')
			->select();
		// 时间表达式-获取上月的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'last month')
			->select();
		// 时间表达式-获取今年的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'year')
			->select();
		// 时间表达式-获取去年的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'last year')
			->select();
		
		// 如果查询当天、本周、本月和今年的时间,还可以简化为
		// 获取今天的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'd')
			->select();
		// 获取本周的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'w')
			->select();
		// 获取本月的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'm')
			->select();
		// 获取今年的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', 'y')
			->select();
		
		// 查询两个小时内的博客
		$rs = Db::table('zht_articles')
			->whereTime('createTime', '-2 hours')
			->select();
		
		// V5.1.17+版本开始,可以支持对两个时间字段的区间比较
		$rs = Db::table('zht_articles')
			->whereBetweenTimeField('createTime', 'replyTime')
			->select();
		// 上面的查询相当于
		$rs = Db::table('zht_articles')
			->whereTime('createTime','<=',time())
			->whereTime('replyTime','>=',time())
			->select();
		echo Db::getlastsql();
		dump($rs);
		exit;
		return $rs;
	}
	
}

版权声明:本篇文章来源于网络。 来源链接

相关推荐
Non-static method think\Config::get() should not be called statically
ThinkPHP5.1 | 2018-12-29 10403
原来是这样use think\Config; 改成这样use think\facade\Config; 下面是官方手册的解释 配置获取 要使用Config类,首先需要在你的类文件中引入 use think\facade\Config; 或者(因为系统做了类库别名,其实就是调用think\facade\Config) u...
thinkPHP5 order多条件排序
ThinkPHP5.1 | 2017-10-24 10272
总结如下: //单一条件排序 $user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select(); //多个条件排序,可以多加一个order...
评论:0条
评论加载中...
发表评论