laravel mdoel 属性说明

1、属性说明


#与模型关联的数据表
protected $table = 'article';	

#主键字段,默认为 id
protected $primaryKey = 'id';

#主键是否默认自增长
public $incrementing = true;

#主键是否默认自增长
public $incrementing = true;

#该模型是否被自动维护时间戳(自动更新create_at/update_at字段)
public $timestamps = false;		

#模型的日期字段的存储格式,具体指参考下方:php 时间字母含义
protected $dateFormat = 'U';

#自定义命名:create_at/update_at字段
const CREATED_AT = 'creation_date';
const UPDATED_AT = 'last_update';

#此模型的连接名称(此模型单独连接其他数据库)
protected $connection = 'connection-name';

#可以被批量赋值的属性,只有在数组里面的属性才能通过 create() 创建
protected $fillable = ['name'];

#不可被批量赋值的属性,所有不在数组里面的属性都是可以被 create() 创建
protected $guarded = ['price'];

#隐藏属性,当模型转为数组或json时,在数组中的字段会隐藏
protected $hidden = ['password'];

#显示属性,当模型转为数组或json时,在数组中的字段会显示
protected $visible = ['title', 'remember_token'];

#默认分页数量
protected $perPage = 15;

#默认给字段赋值
protected $attributes = ['user_limit' => 100];

#给模型追加属性,搭配 getIsAdminAttribute()使用,没有定义方法会报错
#is_admin/get`IsAdmin`Attribute(),is_admin/IsAdmin,自定义对应上即可
protected $appends = ['is_admin'];

2、$appends使用

#model


protected $appends = ['title_creator'];

public function getTitleCreatorAttribute()
{
	return $this->attributes['title_creator'] = $this->title.'-'.$this->creator;
}

model 查询转数组或json时会增加一个字段 title_creator

3、php 时间字母含义

format 字符 说明 返回值例子
--- ---
d 月份中的第几天,有前导零的 2 位数字 0131
D 星期中的第几天,文本表示,3 个字母 MonSun
j 月份中的第几天,没有前导零 131
l(“L”的小写字母) 星期几,完整的文本格式 SundaySaturday
N ISO-8601 格式数字表示的星期中的第几天(PHP 5.1.0 新加) 1(表示星期一)到 7(表示星期天)
S 每月天数后面的英文后缀,2 个字符 stndrd 或者 th。可以和 j 一起用
w 星期中的第几天,数字表示 0(表示星期天)到 6(表示星期六)
z 年份中的第几天 0365
星期 --- ---
W ISO-8601 格式年份中的第几周,每周从星期一开始(PHP 4.1.0 新加的) 例如:42(当年的第 42 周)
--- ---
F 月份,完整的文本格式,例如 January 或者 March JanuaryDecember
m 数字表示的月份,有前导零 0112
M 三个字母缩写表示的月份 JanDec
n 数字表示的月份,没有前导零 112
t 指定的月份有几天 2831
--- ---
L 是否为闰年 如果是闰年为 1,否则为 0
o ISO-8601 格式年份数字。这和 Y 的值相同,只除了如果 ISO 的星期数(W)属于前一年或下一年,则用那一年。(PHP 5.1.0 新加) Examples: 1999 or 2003
Y 4 位数字完整表示的年份 例如:19992003
y 2 位数字表示的年份 例如:9903
时间 --- ---
a 小写的上午和下午值 ampm
A 大写的上午和下午值 AMPM
B Swatch Internet 标准时 000999
g 小时,12 小时格式,没有前导零 112
G 小时,24 小时格式,没有前导零 023
h 小时,12 小时格式,有前导零 0112
H 小时,24 小时格式,有前导零 0023
i 有前导零的分钟数 0059>
s 秒数,有前导零 0059>
u 毫秒 (PHP 5.2.2 新加)。需要注意的是 date() 函数总是返回 000000 因为它只接受 integer 参数, 而 DateTime::format() 才支持毫秒。 示例: 654321
时区 --- ---
e 时区标识(PHP 5.1.0 新加) 例如:UTCGMTAtlantic/Azores
I 是否为夏令时 如果是夏令时为 1,否则为 0
O 与格林威治时间相差的小时数 例如:+0200
P 与格林威治时间(GMT)的差别,小时和分钟之间有冒号分隔(PHP 5.1.3 新加) 例如:+02:00
T 本机所在的时区 例如:ESTMDT(【译者注】在 Windows 下为完整文本格式,例如“Eastern Standard Time”,中文版会显示“中国标准时间”)。
Z 时差偏移量的秒数。UTC 西边的时区偏移量总是负的,UTC 东边的时区偏移量总是正的。 -4320043200
完整的日期/时间 --- ---
c ISO 8601 格式的日期(PHP 5 新加) 2004-02-12T15:19:21+00:00
r RFC 822 格式的日期 例如:Thu, 21 Dec 2000 16:01:07 +0200
U 从 Unix 纪元(January 1 1970 00:00:00 GMT)开始至今的秒数 参见 time()
posted @ 2020-04-30 17:14  pine007  阅读(356)  评论(0编辑  收藏  举报