Laravel教程 八:queryScope 和 setAttribute
直接就是按照上一节所说的那样,我们来说说queryScope和setAttribute在laravel的用法。
关于应用场景
这里我首先是想向大家简单说说这两个知识点得应用场景是什么,我们在开发的时候,总是希望有一种偷懒的方式,所以考虑以下这两个场景:
数据在存入数据库的时候需要进行预先处理,比如考虑一个简单地例子:我们在保存用户的登录密码的时候,都是需要将密码用某种方式加密过后在写入数据库的,我们难道在每一次在提交表单过来之后都对传过来的数据进行一次数据加密么?能不能有一种自动完成对密码入库前就加密的机制呢?这样我们在处理表单的时候就不用关心密码加密的问题了
想一想我们在向用户展示的数据是不是基本上都是从数据库取的呢?那么往往我们会有很多的查询语句,在这样的情况之下很多的查询语句可以就会重复,但是在写代码这一行中,一旦出现多个重复,基本上就会有优化方式存在,所以这个时候queryScope就派上用场了
setAttributes
之前,我们都是将published_at设置为文章创建的日期:
$input['published_at'] = Carbon::now();
然而这并不是我们想要的,我们希望有一种可以控制的方式,比如在表单之中设置文章的发布日期,所以,我们来实现一下:首先将published_at
这个字段放到我们的form之中,在create.blade.php
中,加入published_at
输入框输入:
<div class="form-group">
{!! Form::label('published_at','发布日期') !!}
{!! Form::input('date','published_at',date('Y-m-d'),['class'=>'form-control']) !!}
</div>
这一段代码加在textarea后面,这里使用了Form::input()
,这个方法,因为Form这个类没有类似Form::date()
指定date的方法,所以我们使用Form::input()
并指定input
的类型为date
,并使用date('Y-m-d')
来指定默认值为文章发布当天,但是我们可以修改,我们来看看我们的页面现在是什么样的:
这里我们可以看到我们拿到了published_at
这个字段了,这个时候,可以修改一下ArticleController
中的store()
方法的代码了:
$input = $request->all();
$input['intro'] = mb_substr($request->get('content'),0,64);
Article::create($input);
return redirect('/');
我们删除了$input['published_at'] = Carbon::now();
这一行代码,然后尝试创建一篇文章来看看:
OK,到这里,文章可以创建成功了,但是如果我们看看数据库当中的数据:
这里的日期设置成的格式并不是理想的模式,有没有一种方式可以将其设置为跟created_at
和updated_at
一样的呢?时分秒都可以知道的呢?这个时候就可以使用setAttribute来完成了,在Article.php
中添加下面的方法:
public function setPublishedAtAttribute($date)
{$this->attributes['published_at'] = Carbon::createFromFormat('Y-m-d',$date);
}
这里注意这个写法set+字段名+Attribute
,还有的就是使用驼峰法。比如你要加密密码的时候可以这样:
public function setPasswordAttribute($passowrd)
{$this->attributes['password'] = Hash::make($passowrd);//仅仅是举例
}
这里我们使用了Carbon这个类,因为我们还想将published_at
字段作为Carbon对象来处理,这样后期会有很大的好处。注意在文件头部使用use Carbon\Carbon;
来引入Carbon。这个时候我们再来发表一次:
再来看看数据库:
这样一来格式是对了,那么再来为Article.php
添加一行代码使published_at
作为Carbon对象来处理:
protected $dates = ['published_at'];
对这样就完成了,关于更多地Carbon好处和使用特性,我们在后面再说。
queryScope
上面实现了用published_at
实现了文章的发布日期,但是现在的文章展示还是原来的样式,这并不是我们想要的结果,因为我们刚刚设置发表日期为9-12
的文章(写文章的时候为9-08
)也展示出来了,我们得限制一下。首先我们可以在查询的时候直接实现,比如在ArticleController
的index()
方法中将查询语句写成这样:
$articles = Article::where('published_at','<=',Carbon::now())->latest()->get();
我们使用where()
直接限制published_at
时间小于或等于当前时间的文章才进行显示,看看效果:
发现在未来时间发布的文章确实隐藏了,这样貌似已经达到了目的,为什么还要引入qeuryScope这个用法呢?这是因为考虑到代码的重用性,比如我们要是多个地方使用到Article::where('published_at','<=',Carbon::now())
这个条件限制呢,我们有没有一种方式可以将查询语句写成类似下面这种形式呢?
$articles = Article::latest()->published()->get();
就是直接使用published()
这个自定义的方法来代替where('published_at','<=',Carbon::now())
呢,这样代码可读性也会更好。
所以我们就来说说,queryScope的用法了,想想我们之前设置published_at
这个字段的目的:
我们希望可以对文章进行简单地管理,比如我们在写系列文章的时候,有可能一天写了好几篇,但是这种时候其实我们发一篇文章就好了,每天消化一篇文章就很不错了,所以作为作者,我并不想还没到发布日期的文章就展示给用户看,但是,我写了文章也想把它存入数据库,让它在该发布的日期自动显示,这样就好了。于是,我们可以好好利用一下published_at这个字段
在我们的Article.php
中增加下面的方法:
public function scopePublished($query)
{$query->where('published_at','<=',Carbon::now());
}
这里注意一下写法scope+自定义的方法名字
,还有就是一如既往的驼峰法。比如我们想使用published()
这个方法,就定义为scopePublished($query)
。这个时候就可以真正的使用上面说的查询了,在ArticleController
的index()
方法中:
$articles = Article::latest()->published()->get();
再去看看效果,相信你刷新之后还是一样的。
总结
又是最后的结尾了,这里我们简单的介绍了queryScope和setAttribute的用法,下一节打算说说Eloquent的一个重要的内容:Eloquent Relationship。那个时候也就会越来越觉得laravel的强大了。
https://www.codecasts.com/blog/post/programming-with-laravel-5-queryscope-and-set-attribute
Laravel教程 八:queryScope 和 setAttribute相关推荐
- Laravel教程 一:安装及环境配置
Laravel教程 一:安装及环境配置 此文章为原创文章,未经同意,禁止转载. Homestead 最近在SF上面看到越来越多的Laravel相关的问题,而作为一个Laravel的脑残粉,本来打算有机 ...
- MongoDB 教程八(结语): 一网打尽当下NoSQL类型、适用场景及使用公司
在过去几年,关系型数据库一直是数据持久化的唯一选择,数据工作者考虑的也只是在这 些传统数据库中做筛选,比如SQL Server.Oracle或者是MySQL.甚至是做一些默认的选择,比如使用.NET的 ...
- (转)jquery基础教程八 load方法及小技巧
首先我们看看手册上的描述 load(url, params, callback) 装入一个远程HTML内容到一个DOM结点. 注意:避免用装入的scripts脚本,装入脚本改用$.getScript. ...
- Laravel教程 六:表单 Forms
Laravel教程 六:表单 Forms 此文章为原创文章,未经同意,禁止转载. Form laravel 5.2 之后请使用 laravelcollective/html 替换 illuminate ...
- Laravel教程 四:数据库和Eloquent
Laravel教程 四:数据库和Eloquent 此文章为原创文章,未经同意,禁止转载. Eloquent Database 上一篇写了一些Laravel Blade的基本用法和给视图传递变量的几种方 ...
- 2021年最好的Laravel教程
2021年最好的Laravel教程 20 Best Laravel Tutorials in 2021 为什么学习Laravel 完善的生态系统 官方提供的软件包(Package) 服务器管理工具和平 ...
- php laravel 入门教程,Laravel 5 系列入门教程(一)【最适合中国人的 Laravel 教程】...
Laravel 5 系列入门教程(一)[最适合中国人的 Laravel 教程] 2015-3-7 / 阅读数:314392 / 分类: Laravel 十分建议学习 5.5,跟 5.0 比变化非常大. ...
- laravel教程 第一章安装laravel
#laravel教程# ##第一章 安装laravel## ###前言 ### 有很多人,都在纠结于自己学什么框架,用什么框架.在这里我想告诉你,框架都是死的,但是人是活的,只要你明白的框架的基本原理 ...
- Laravel 教程:使用Fast Excel解决导出超大 XLSX 文件(千万级)带来的内存问题
TL;DR: 本文介绍 Laravel 的 FastExcel 组件,文中会对 PHP generators 速览,并给出如何在节约内存的同时结合两者从数据集生成 Excel 文件. 关于 FastE ...
最新文章
- layui table 滚动 键盘
- python小项目案例-python_flask小项目实例-编一个小网站
- java word 加密_如何通过Java实现加密、解密Word文档
- 功能对等四个原则_佛山房屋加固工程需遵循的原则与步骤
- .NET常用功能和代码[总结与收藏]
- Service混合开启笔记(startService+bindService)
- 8086汇编工作环境_ARM汇编进阶
- stack 的优势 - 每天5分钟玩转 Docker 容器技术(113)
- 「2012-12-29」3x3手机锁屏矩阵图像的组合数量
- 【数字信号处理】基于matlab GUI数字信号处理系统【含Matlab源码 1088期】
- linux yum安装jdk
- html js实现分页代码,js分页代码示例
- php 调用speex解码库,android 用speex做回音消除
- easyui获取图片路径_Easyui filebox(文件框)_EasyUI 插件
- 用metasploit(msf)复现MS17-010(经典的永恒之蓝)SMB漏洞
- u盘变o字节怎么修复_U盘变成0字节了数据怎么恢复
- mysql数据库在政务项目中的运用_数据库区域论文,关于MySQL数据库在域名系统中的应用实现相关参考文献资料-免费论文范文...
- Cisco VPP(1) 简介
- 2021年各省高考日语成绩查询,2021年各省高考满分是多少
- 神经网络中的过拟合的原因及解决方法、泛化能力、L2正则化