关于本站
“最难不过坚持”
本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作
有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339
2655
39
分类目录
最新评论
- https://jueru.net/
-
- :weixiao:
-
- :shuijiao: :weiqu: :zhenbang: :leng:
-
- :yiwen: :yiwen: :yiwen: :yiwen:
-
- 这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
-
文章标签更多
打开边栏(ESC)
关闭边栏(ESC)
thinkphp原生态mysql分页_Thinkphp5 原生sql分页操作
页面分页一直用的是
Model
$rs = $this->where($where)
->order('goodsId', 'desc')
->paginate(10,false,['query' => request()->param()])
Html
{volist name='list' id='vo'}
{/volist}
{$list|raw}
这种形式
但是有个复杂的sql语句,需要用到原生sql语句写,怎么实现分页呢,还能用{$list|raw}显示分页吗?
方法:
//use think\paginator\driver\Bootstrap; 记得引入 $pageSize=8;//每页8条 $currPage=input('page',1); $list = Db::query("select * from osc_sms order by id limit ?,?",[($currPage-1)*$pageSize,$pageSize]); $total = Db::query("select count(*) cnt from osc_sms")[0]['cnt']; $pagernator = Bootstrap::make($list,$pageSize,$currPage,$total,false,['path'=>Bootstrap::getCurrentPath(),'query'=>request()->param()]);得到的结果$pagernator和上面的$rs是一样的,都是数据对象,在前台页面可以直接{$list|raw}获取分页
如果要对得到的数据,循环处理怎么办呢?
之前是用each循环
$rs = $this->where($where) ->order('goodsId', 'desc') ->paginate(10,false,['query' => request()->param()]) ->each(function($item, $key) use ($m){ $item['catTitles'] = $m->getCatTitlesForAttribute($item['shopGoodsCatIdPath']); return $item; });现在的情况,同样用each
$pagernator = Bootstrap::make($list,$pageSize,$currPage,$total,false,['path'=>Bootstrap::getCurrentPath(),'query'=>request()->param()]) ->each(function($item, $key) use ($m,$shopId){ $item['catTitles'] = $m->getCatTitlesForAttribute($item['shopGoodsCatIdPath']); return $item; });很方便。
不要用foreach循环$pagernator然后修改数据,反正我这样没有成功。
赏
相关推荐
Non-static method think\Config::get() should not be called statically
原来是这样use think\Config;
改成这样use think\facade\Config;
下面是官方手册的解释
配置获取
要使用Config类,首先需要在你的类文件中引入
use think\facade\Config;
或者(因为系统做了类库别名,其实就是调用think\facade\Config)
u...
thinkPHP5 order多条件排序
总结如下:
//单一条件排序
$user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select();
//多个条件排序,可以多加一个order...
评论加载中...