3分钟短文:Laravel模型读数据的那个“障眼法”
引言
通过前几篇文章视图和路由的介绍,我们通过模型对象操作数据库表。
laravel模型的精巧设计使得我们操作数据层逻辑更加得心应手。
本文我们来说说模型在读写数据中所使用的技巧。
日期时间格式化
先从最常用的地方着手,比如在迁移文件内使用的 timestamps方法,就是在表内生成 created_at和updated_at两个 datetime 类型的字段,用于标记该记录的创建时间和更新时间。
laravel框架继承了广泛使用稳定可靠的 Carbon 类库用于操作日期时间。为了测试方便,我们不需要写额外的代码,直接使用 tinker 命令行交互工具,在命令行输入:
tinker
进入交互界面,然后我们使用模型查询一条 events 表的数据,并访问其属性:
namespace App;
$event = Event::find(1);
$event->created_at
打印 created_at 属性输入内容如下:
=> IlluminateSupportCarbon {#819
+"date": "2020-10-02 04:01:38.000000",
+"timezone_type": 3,
+"timezone": "Asia/Shanghai (+08:00)",
}
输出的是一个 Carbon 对象。也可以调用格式化方式返回需要的格式,比如返回时间字符串:
$event->created_at->toDateString()
// "2020-10-02"
或者自定义格式:
$event->created_at->format('Y-m-d H:i')
// "2020-10-02 04:01"
在模型内使用该格式化方式很容易,添加如下属性定义:
protected $dates = ['created_at','updated_at','started_at'];
那么这三个字段都会使用 Carbon 进行格式化,在访问模型对象属性时,就会返回该Carbon对象。
访问器
其实上一节所说的日期时间的格式化,正是laravel模型访问器的功能。专门用于在模型层面,修改模型属性的展示方式。定义一个访问器非常简单,就是在模型内添加规范格式的方法函数。比如想要使用
$model->human_size
而数据库没有这个字段,模型也没有这个属性,那么使用访问器好了,添加如下定义:
public funciton getHumanSizeAttribute(){}
方法内添加要处理的逻辑,并返回相应的值即可。使用 ->human_size 属性访问,就相当于访问了该方法。
下面是一个相对复杂的方法,根据不同情况返回字段name的值:
如果在忽略列表,就使用纯小写字母,如果不是忽略列表的元素,首字母大写。最后组装为空格间隔的字符串返回。
在程序内使用 ->name 访问的时候,就会调用该方法。我们仍然使用 tinker 进行临时测试:
namespace App;
$e = new Event;
$e->name = "let's learn a Little Laravel together";
$e->Save();
这里完成了模型的创建和属性赋值,并写入数据库。save方法会返回一个 Events 模型对象,直接访问其方法:
$e->name
// 输出 "Let's Learn a Little Laravel Together"
正是我们定义的访问器的修改策略。
对于已存在的字段属性,创建一些常用的访问器方法能提高效率,比如知道用户的姓氏和名字,我们可以返回其全名,模型内创建如下方法:
class User extends Model {
public function getFullnameAttribute()
{
return $this->first_name . " " . $this->last_name;
}
}
声明完成时候,在代码内使用:
$user = User::find(12);
echo $user->fullname;
虽然没有fullname属性,可是通过访问器我们获得了类似的能力。这是laravel提供的语法糖,很好使!
写在最后
本文通过日期时间字段的格式化方法,引申出laravel模型的访问器功能,并通过实例介绍了具体的用法。
访问器虽然好用,看上去像是模型的方法,实际上却是调用了访问器方法。书写起来很简洁,但是对于维护者要排查为数众多的访问器,并且没有IDE的自动跳转,这着实很考验开发者的功底!
Happy coding :-)
- 2017年度最不安全密码报告,看看你的密码安全吗?
- 数据结构C#版笔记--顺序表(SeqList)
- 数据结构C#版笔记--单链表(LinkList)
- 操作系统 页式存储 页与块之间的关系详解
- 数据结构C#版笔记--双向链表(DbLinkList)
- 斐波那契数列与IE9
- DateTime.ToString()输出"年/月/日 时:分:秒"的格式
- Flash在线拍摄用户头象
- win7 64位下如何折腾Tubro C 3.0
- TweenLite的又一应用:图片的拼图加载效果
- mysql创建数据表时如何判断是否已经存在?
- 温故知新:接口的隐式实现与显式实现
- 也谈枚举ToString()性能的改进
- silverlight:利用telerik中的zip类对字符串进行压缩、解压
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- SpringBoot整合SpringBatch实用简例
- 解决JPA懒加载典型的N+1问题-注解@NamedEntityGraph
- 基于Shiro,JWT实现微信小程序登录完整例子
- Spring Cloud Eureka 总结
- Spring Cloud Feign 总结
- 掘金15W沸点简单分析(一)
- SpringBoot整合Shiro实现基于角色的权限访问控制(RBAC)系统简单设计从零搭建
- 基于AOP和ThreadLocal实现日志记录
- 搭建prometheus+grafana监控SpringBoot应用入门
- 掘金15W沸点简单分析(二)
- 老生常谈SpringAop日志收集与处理做的工具包
- 线程间通信wait---notify
- Ubuntu安装Oracle Java8
- CentOS7安装Git
- RocketMQ-环境搭建(单master模式-ubuntu版)