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 简化了与数据库的交互,提高了开发效率。

相关推荐
MZ_ZXD0016 小时前
springboot汽车租赁服务管理系统-计算机毕业设计源码58196
java·c++·spring boot·python·django·flask·php
朱皮皮呀12 小时前
Spring Cloud——服务注册与服务发现原理与实现
运维·spring cloud·eureka·服务发现·php
花开富贵贼富贵17 小时前
计算机网络技术学习-day4《路由器配置》
网络·智能路由器·php
BingoGo19 小时前
PHP 集成 FFmpeg 处理音视频处理完整指南
后端·php
望获linux1 天前
【实时Linux实战系列】基于实时Linux的物联网系统设计
linux·运维·服务器·chrome·php
fakaifa2 天前
点大餐饮独立版系统源码v1.0.3+uniapp前端+搭建教程
小程序·uni-app·php·源码下载·点大餐饮·扫码点单
挨踢攻城2 天前
华为 | SD-WAN场景丢包类问题定位
网络·华为·php·hcie·hcia·hcip·厦门微思网络
fakaifa2 天前
【最新版】CRMEB Pro版v3.4系统源码全开源+PC端+uniapp前端+搭建教程
人工智能·小程序·uni-app·php·crmeb·源码下载·crmebpro
lingggggaaaa2 天前
小迪安全v2023学习笔记(六十二讲)—— PHP框架反序列化
笔记·学习·安全·web安全·网络安全·php·反序列化
Q_Q19632884753 天前
python的电影院座位管理可视化数据分析系统
开发语言·spring boot·python·django·flask·node.js·php