0

0

Laravel 5系列教程八:queryScope 和 setAttribute

php中文网

php中文网

发布时间:2016-06-23 13:26:57

|

1234人浏览过

|

来源于php中文网

原创

原文来自 https://laravist.com/article/16

laravist是我刚刚上线的laravel社区,有任何与laravel相关的问题可以到这里来问我,我会尽力去帮大家解决问题,后期会尝试录制一些视频教程,形式大概是这样的

https://laravist.com/lesson/1

直接就是按照上一节所说的那样,我们来说说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','

    $articles = Article::latest()->published()->get();

    就是直接使用published()这个自定义的方法来代替where('published_at','

    所以我们就来说说,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的强大了。

    最后:Happy Hacking

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

    本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

    463

    2026.02.13

    微博网页版主页入口与登录指南_官方网页端快速访问方法
    微博网页版主页入口与登录指南_官方网页端快速访问方法

    本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

    135

    2026.02.13

    Flutter跨平台开发与状态管理实战
    Flutter跨平台开发与状态管理实战

    本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

    64

    2026.02.13

    TypeScript工程化开发与Vite构建优化实践
    TypeScript工程化开发与Vite构建优化实践

    本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

    20

    2026.02.13

    Redis高可用架构与分布式缓存实战
    Redis高可用架构与分布式缓存实战

    本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

    26

    2026.02.13

    c语言 数据类型
    c语言 数据类型

    本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    29

    2026.02.12

    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

    本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

    14

    2026.02.12

    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

    本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

    524

    2026.02.12

    PostgreSQL性能优化与索引调优实战
    PostgreSQL性能优化与索引调优实战

    本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

    53

    2026.02.12

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号