Laravel 自带的 Eloquent ORM 提供了一个美观、简单的与数据库打交道的方案,每张数据表都对应一个与该表进行交互的“Model模型”,模型允许你在表中进行数据查询,以及插入、更新、删除等操作。
模型文件的位置
默认情况laravel模型在app目录的根目录下面。但这种情况不利于我们日后项目维护,所以我们一般建议手动创建一个目录,这样更加的方便去管理和维护。
创建模型
php artisan make:model [目录名/]模型文件名
# 分目录的
php artisan make:model Models/Member
# 创建模板并生成迁移文件 实际工作中,就是创建模型同时就创建好了迁移文件
php artisan make:model Models/Article –m
# -m 生成迁移文件
模型限制
定义表名($table)
模型所对应的默认表名是模型类名复数形式,如果表名不统一则需要指定一下。
// 指定表名
protected $table = 'member';
指定主键名($primaryKey)
laravel中默认的主键ID名为id,如果你创建的表字段中主键ID的名称不为id,则需要通过 $primaryKey 来指定一下。
// 指定主键的名称
protected $primaryKey = 'mid';
指定时间戳($timestamps)
默认情况下,模型操作会认为在你的数据库表有 created_at
和 updated_at
字段。如果你不希望让模型来自动维护这两个字段,可在模型内将 $timestamps
属性设置为 false。
// 时间戳 这里一定要注意它是用的public
public $timestamps = false;
批量赋值($fillable 与 $guarded)
当通过create
方法来保存数据的时候,你需要先在你的模型上定义$fillable
或 $guarded属性。
// 批量赋值
# 白名单
protected $fillable = ['允许添加的字段名'];
# 黑名单
protected $guarded = ['拒绝添加的字段名'];
CURD基本操作
添加数据
# 方法一
save() # 对象属性方式 返回模型对象
# 方法二
insert() #数组方式 可以添加一条或多条,返回true/false
# 方法三
create() # 数组方式 需要在模型中设置好fillable或guarded属性 返回是模型对象
查询数据
# 查询单条
first() find($id) 要想让find不报错,一定字段为id或者模型中定义了主键名称
# 查询多条
get()
# 条件
where()
# 排序
orderBy()
# 取指定的值
value()
# 取指定的列
pluck()
# 查询总记录数
count()
修改数据
# 方法一
save() # 对象属性方式 返回的是模型对象
# 方法二
update() # 数组 返回受影响行数
删除数据
# 删除 一定要指定条件删除
delete() # 对象删除
destroy($id) 静态方法删除 默认表字段主键名为id,如果不是则需要模型中定义一下
# 软删除
1、在表字段中要有deleted_at字段 可以在迁移文件中直接添加一个方法 $table->softDeletes()
2、在模型中引入 trait use SoftDelele;
protected $dates = [删除标识字段名 deleted_at]
软删除
修改迁移文件
#删除表 并执行迁移和填充
php artisan migrate:refresh --seed
修改模型文件
控制器
软删除说白就是给标识字段中添加一些数据,让此字段不为null
faker来进行数据填充
https://packagist.org/packages/fzaninotto/faker
larvel从5之后默认就已经安装了此扩展包
第1步:创建数据工厂
php artisan make:factory 工厂的文件名 -m 模型名(目录 Models/Article)
第2步:在种子文件中调用
第3步:DatabaseSeeder文件中调用种子
第4步:执行种子
php artisan migrate:refresh --seed
第5步:本地化
方案1
方案2 推荐
模型事件
https://learnku.com/docs/laravel/5.6/eloquent/1403#events
方案1:在AppServiceProvider中的boot方法中注册模型对应的观察者。
方案2:在本模型中去注册观察 推荐