Laravel Eloquent怎么用_Laravel Eloquent ORM使用教程

絕刀狂花
发布: 2025-09-30 20:24:01
原创
905人浏览过
Laravel Eloquent通过模型操作数据库,无需写SQL即可实现增删改查。定义模型时默认关联复数表名,可自定义表名、主键和时间戳格式。常用查询包括all()、find()、where()等,支持批量插入需设置$fillable。更新可用save()或update(),删除用delete()或destroy()。支持一对一、一对多、多对多关联,通过hasOne、hasMany、belongsToMany定义。还可使用访问器格式化读取值,修改器处理写入值,使代码更清晰易维护。

laravel eloquent怎么用_laravel eloquent orm使用教程

Laravel Eloquent 是 Laravel 框架自带的 ORM(对象关系映射)系统,它让数据库操作变得像操作 PHP 对象一样简单。你不需要写复杂的 SQL 语句,就能完成增删改查等操作。下面带你快速掌握 Eloquent 的基本用法和常用技巧。

定义模型与数据库表关联

每个 Eloquent 模型对应一张数据库表。默认情况下,模型会自动关联“复数形式”的表名。

例如:

创建一个 User 模型,默认会对应 users 表。

使用 Artisan 命令生成模型:

php artisan make:model User
登录后复制

如果你的表名不是复数,或想自定义表名,可以在模型中指定:

class User extends Model<br>{<br>    protected $table = 'my_users'; // 自定义表名<br>}
登录后复制

还可以设置主键和时间戳字段:

class User extends Model<br>{<br>    protected $primaryKey = 'id_user'; // 自定义主键<br>    public $timestamps = true;         // 是否自动维护 created_at 和 updated_at<br>    protected $dateFormat = 'U';       // 时间戳格式(如 Unix 时间戳)<br>}
登录后复制

基本的增删改查操作

Eloquent 提供了简洁的方法进行数据操作。

查询数据
  • User::all(); — 获取所有用户
  • User::find(1); — 根据主键查找一条记录
  • User::where('name', 'John')->get(); — 条件查询,返回集合
  • User::where('name', 'John')->first(); — 返回第一条记录
  • User::findOrFail(1); — 找不到时抛出 404 异常
新增数据
$user = new User;<br>$user->name = 'Alice';<br>$user->email = 'alice@example.com';<br>$user->save();
登录后复制

或者使用批量赋值(需要在模型中设置 $fillable):

class User extends Model<br>{<br>    protected $fillable = ['name', 'email'];<br>}
登录后复制

然后这样插入:

User::create(['name' => 'Bob', 'email' => 'bob@example.com']);
登录后复制
更新数据
$user = User::find(1);<br>$user->name = 'New Name';<br>$user->save();
登录后复制

也可以直接调用 update:

AppMall应用商店
AppMall应用商店

AI应用商店,提供即时交付、按需付费的人工智能应用服务

AppMall应用商店 56
查看详情 AppMall应用商店
User::where('active', 1)->update(['status' => 'approved']);
登录后复制
删除数据
$user = User::find(1);<br>$user->delete();
登录后复制

或通过主键删除:

User::destroy(1);<br>User::destroy([1, 2, 3]); // 删除多个
登录后复制

条件删除:

User::where('score', '<', 60)->delete();
登录后复制

使用模型关联(关系)

Eloquent 支持多种关联关系,让你轻松处理表之间的连接。

一对一

比如用户(User)有一个人资料(Profile):

// 在 User 模型中<br>public function profile()<br>{<br>    return $this->hasOne(Profile::class);<br>}
登录后复制

使用:$user->profile 一对多

用户有多条评论:

// 在 User 模型中<br>public function comments()<br>{<br>    return $this->hasMany(Comment::class);<br>}
登录后复制

使用:$user->comments 多对多

用户和角色之间是多对多关系,中间表为 role_user

// 在 User 模型中<br>public function roles()<br>{<br>    return $this->belongsToMany(Role::class);<br>}
登录后复制

使用:$user->roles,还可以附加数据:$user->roles()->attach($roleId)

访问器与修改器

你可以对字段进行格式化处理。

访问器(获取时处理)

比如将名字首字母大写:

// 在 User 模型中<br>public function getNameAttribute($value)<br>{<br>    return ucfirst($value);<br>}
登录后复制
修改器(存入时处理)

比如将邮箱统一转为小写:

public function setEmailAttribute($value)<br>{<br>    $this->attributes['email'] = strtolower($value);<br>}
登录后复制
基本上就这些核心内容。Eloquent 功能强大,但上手并不难。只要定义好模型,就可以用面向对象的方式操作数据库,代码更清晰,也更容易维护。

以上就是Laravel Eloquent怎么用_Laravel Eloquent ORM使用教程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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