laravel的ORM 对象关系映射

Laravel 中的 ORM(Eloquent ORM)是 Laravel 框架内置的一种对象关系映射系统,用于在 PHP 应用中与数据库进行交互。Eloquent 提供了一种优雅而直观的语法,使得开发者可以使用面向对象的方式进行数据库查询和操作。

定义模型(Models)

在 Laravel 中,每个数据库表对应一个模型。模型是 Eloquent ORM 的核心,它与数据库表之间建立了映射关系。

php 复制代码
// 例如,定义一个 User 模型
namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
    // 指定模型对应的数据表
    protected $table = 'users';
}

查询数据

php 复制代码
// 查询所有用户
$users = User::all();

// 查询单个用户
$user = User::find(1);

// 使用条件查询
$users = User::where('name', 'John')->get();

// 还可以链式调用多个查询条件
$users = User::where('name', 'John')->orWhere('name', 'Jane')->get();

插入和更新数据

php 复制代码
// 插入一条数据
$user = new User;
$user->name = 'John';
$user->email = 'john@example.com';
$user->save();

// 更新数据
$user = User::find(1);
$user->name = 'New Name';
$user->save();

删除数据

php 复制代码
// 删除一条数据
$user = User::find(1);
$user->delete();

// 删除满足条件的数据
User::where('name', 'John')->delete();

关联关系

php 复制代码
// 定义一对多关系
class Post extends Model
{
    public function user()
    {
        return $this->belongsTo(User::class);
    }
}

// 使用关联
$post = Post::find(1);
$user = $post->user;

这只是 Laravel Eloquent ORM 的基本用法,该 ORM 还支持更多高级特性,如软删除、观察者模式、查询构造器等。通过 Eloquent,Laravel 简化了与数据库的交互,提高了开发效率。

相关推荐
9***P3347 小时前
PHP代码覆盖率
开发语言·php·代码覆盖率
2501_941623329 小时前
C++高性能网络服务器与epoll实战分享:大规模并发连接处理与事件驱动优化经验
开发语言·php
catchadmin11 小时前
PHP True Async RFC 被拒——原生异步离 PHP 还有多远?
开发语言·php
J***793911 小时前
PHP在电商中的Magento
开发语言·php
云计算老刘12 小时前
1.项目实战:LAMP-LNMP-分离部署
linux·mysql·php·apache·mariadb
q***062915 小时前
ThinkPHP和PHP的区别
开发语言·php
Protein_zmm17 小时前
第一章 计算机网络和因特网(下)
服务器·计算机网络·php
依了个旧19 小时前
🚀 告别手写注释!Laravel 自定义命令创建模型时自动生成 @property 属性提示
laravel
q***99419 小时前
IPV6公网暴露下的OPENWRT防火墙安全设置(只允许访问局域网中指定服务器指定端口其余拒绝)
服务器·安全·php
u***u68519 小时前
PHP在电商中的WooCommerce
开发语言·php