`
xieye
  • 浏览: 830844 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

php的db类库Eloquent单独使用系列(8)- 多对多关联

    博客分类:
  • PHP
阅读更多
我的Eloquent单独使用系列文章
php的db类库Eloquent单独使用系列(1)
php的db类库Eloquent单独使用系列(2) - 分页
php的db类库Eloquent单独使用系列(3) - sql日志
php的db类库Eloquent单独使用系列(4)- 事件监听
php的db类库Eloquent单独使用系列(5)- 模型转数组
php的db类库Eloquent单独使用系列(6)- 一对一关联
php的db类库Eloquent单独使用系列(7)- 一对多关联
php的db类库Eloquent单独使用系列(8)- 多对多关联
php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身
php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多
php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性
php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2



本系列文章的目的就是脱离laravel环境使用Eloquent,因为它好用。
本系列文章所有代码均测试通过。Eloquent版本:5.4.27

本文的目的是使用多对多关联。
首先建表,一个用户有多个角色,一个角色可对应多个用户。需建3张表才能满足需求。
CREATE TABLE users (
  id int(11) NOT NULL AUTO_INCREMENT,
  name varchar(50)  NOT NULL DEFAULT '' COMMENT '用户名称',
  age int(11) NOT NULL DEFAULT '0' COMMENT '年龄',
  PRIMARY KEY (id)
);

CREATE TABLE roles (
  id int(11) NOT NULL AUTO_INCREMENT,
  name varchar(50)  NOT NULL DEFAULT '' COMMENT '角色名称',
  PRIMARY KEY (id)
);

CREATE TABLE user_roles (
  id int(11) NOT NULL AUTO_INCREMENT,
  user_id int  NOT NULL DEFAULT 0 COMMENT '用户id',
  role_id int  NOT NULL DEFAULT 0 COMMENT '角色id',
  create_time int not null default 0 comment '创建时间',
  PRIMARY KEY (id)
);


源代码
总共3个文件,主程序,用户模型类,角色模型类,注意没有关联表模型!
User.php
<?php
namespace app\model;
use \Illuminate\Database\Eloquent\Model;

/**
 * User模型类
 */
class User extends Model 
{
    protected $table = 'users';
    public $timestamps = false;
    
    public function roles()
    {
        // 重要说明:参数2是关联表名,参数3是关联表里对应本类的外键,参数4对应参数1的外键
        return $this->belongsToMany('app\model\Role', 'user_roles' , 'user_id', 'role_id')
            ->withPivot('create_time' );
    }
}


Role.php
<?php
namespace app\model;
use \Illuminate\Database\Eloquent\Model;

/**
 * Role模型类
 */
class Role extends Model 
{
    protected $table = 'roles';
    public $timestamps = false;
    
    public function users()
    {
        // 重要说明:参数2是关联表名,参数3是关联表里对应本类的外键,参数4对应参数1的外键
        return $this->belongsToMany('app\model\User', 'user_roles' , 'role_id', 'user_id')
            ->withPivot('create_time' );
    }
}


主程序:
<?php
namespace app\control;

use Illuminate\Database\Capsule\Manager;
use app\model\User;
use app\model\Role;

class Ill3
{
    /**
     * 主程序。
     */
    public function index() 
    {
        $db = new Manager ();
        $db->addConnection ( [ 
            'driver' => 'mysql',
            'host' => '127.0.0.1',
            'database' => 'test1',
            'username' => 'root',
            'password' => 'root',
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '' 
        ] );
        $db->setAsGlobal ();
        $db->bootEloquent ();
      
        $db::delete('delete from users ');
        $db::delete('delete from roles ');
        $db::delete('delete from user_roles ');
        
        $user = new User ();
        $user->name = '用户1';
        $user->id = 1;
        $user->save (); // 新模型添加
        $user = new User ();
        $user->name = '用户2';
        $user->id = 2;
        $user->save (); // 新模型添加
        
        $role = new Role();
        $role->id = 1;
        $role->name = '超级管理员';
        $role->save (); // 新模型添加
        
        $role = new Role();
        $role->id = 2;
        $role->name = '管理员';
        $role->save (); // 新模型添加
        
        $role = new Role();
        $role->id = 3;
        $role->name = '普通用户';
        $role->save (); // 新模型添加
        
        $db::table('user_roles')->insert([
            'user_id' => 1, 
            'role_id' => 2,
            'create_time' => time(),
        ]);
        $db::table('user_roles')->insert([
            'user_id' => 1,
            'role_id' => 3,
            'create_time' => time(),
        ]);
        $db::table('user_roles')->insert([
            'user_id' => 2,
            'role_id' => 2,
            'create_time' => time(),
        ]);
        echo "<h2>用户1的所有角色</h2>";
        echo User::find(1)->roles->toJson(JSON_UNESCAPED_UNICODE);
        echo "<br>";
        
        echo "<h2>角色2的所有用户</h2>";
        echo Role::find(2)->users->toJson(JSON_UNESCAPED_UNICODE);
        echo "<br>";
        echo '<br>all ok!';
    }
}


浏览器输出


总结:
  • 通过pivot属性可读取中间表的字段值
  • 竟然不需要替中间表建模型
  • 和前面一样,调用的方法不带括号,动态属性调用如 roles
  • toJson带参数可以避免中文被编码

  • 大小: 21 KB
0
0
分享到:
评论

相关推荐

    Laravel开发-eloquent-uuid-for-key

    1. **安装扩展包**:通常我们可以使用`spatie/laravel-eloquent-has-many-deep`这个扩展包,它为Eloquent提供了对UUID的支持。通过Composer安装: ``` composer require spatie/laravel-eloquent-has-many-deep `...

    Laravel开发-eloquent-single-state-marking-store

    此外,Eloquent还提供了查询构建器,用于构建和执行SQL查询,以及关系(Relationships)功能,用来处理一对多、一对一、多对多等复杂的数据库关联。 单一状态标记存储(Single State Marking Store)是一种设计模式...

    Laravel开发-eloquent-extended-cast-model

    Eloquent-Extended-Cast-Model库正是对这一特性的扩展,它使得开发者可以创建自定义的类型转换器,这些转换器可以处理更复杂的数据格式,如JSON、数组、甚至是其他自定义的序列化和反序列化逻辑。这在处理非标准数据...

    Laravel开发-eloquent-log-lazy-loading

    例如,如果我们有一个`User`模型,它有一对多的`posts`关系,我们可以通过以下方式获取用户及其文章: ```php $user = User::find(1); foreach ($user-&gt;posts as $post) { // ... } ``` 当第一次访问`$user-&gt;posts...

    Laravel开发-eloquent-extended-cast-model .zip

    这个压缩包“Laravel开发-eloquent-extended-cast-model .zip”很可能包含了一些关于如何扩展Eloquent模型的自定义类型转换(casts)的教程或示例代码。 Eloquent的模型类与数据库表一一对应,每个模型实例代表表中...

    Laravel开发-eloquent-single-table-inheritance

    在Laravel框架中,Eloquent ORM(对象关系映射)是其强大且优雅的数据操作工具。Eloquent提供了许多高级特性,其中包括单表继承(Single Table Inheritance,STI)。本教程将深入探讨如何在Laravel项目中利用...

    Laravel开发-eloquent-model-generator

    使用Eloquent-Model-Generator的步骤可能包括以下几点: 1. 安装:首先,你需要将该工具通过Composer添加到你的Laravel项目的依赖中,通常使用`composer require`命令。 2. 配置:配置文件中,你需要指定数据库连接...

    ros2-eloquent-20191122-windows-release-amd64.zip

    ROS是一个用于在不同进程间匿名的发布、订阅、传递信息的中间件。 ROS2系统的核心部分是ROS网络(ROS Graph)。ROS网络是指在ROS系统中不同的节点间相互通信的连接关系。 ROS Graph这里翻译成了ROS网络,因为我觉得...

    php一些比较常用类库及例子

    以上只是PHP开发中常用类库的一部分,实际开发中还有更多优秀的类库,如Laravel的Eloquent ORM、Guzzle HTTP客户端库等,它们极大地提高了开发效率和代码质量。了解并熟练使用这些类库,将使你的PHP开发工作更加...

    Laravel开发-laravel-eloquent-mysqli

    总之,`laravel-eloquent-mysqli` 项目旨在帮助开发者了解和实践在 Laravel 中使用 mysqli 驱动进行数据库操作,这对于那些需要充分利用 MySQL 扩展特性的项目来说,是一个有价值的资源。在实际开发中,根据项目需求...

    Laravel开发-eloquent-base-model

    "Laravel开发-eloquent-base-model" 主题聚焦于Eloquent ORM中的基础模型(Base Model),它是所有自定义模型类的基类,为开发者提供了许多便利的功能和接口。 Eloquent Base Model位于`Illuminate\Database\...

    Laravel开发-eloquent-sortable

    Eloquent提供了简单、直观的方式来处理数据库中的数据,而"eloquent-sortable"则是一个扩展,它为Eloquent模型增加了排序功能,允许我们轻松地对数据库记录进行排序。这个扩展的使用大大简化了在应用程序中实现动态...

    Laravel开发-eloquent-state-machine

    在Laravel框架中,Eloquent ORM(对象关系映射)是用于数据库操作的强大工具,而...通过`eloquent-state-machine-master`这个项目,我们可以学习并实践如何在Laravel项目中有效地集成和使用Eloquent State Machine。

    Laravel开发-eloquent-search-map

    composer require arcanedev/eloquent-search-map ``` 然后,在你的模型中引入并使用`Arcanedev\\Searchable\\Searchable` Trait: ```php use Arcanedev\\Searchable\\Searchable; class YourModel extends ...

    Laravel开发-eloquent-custom

    通过定义一对一、一对多、多对多等关系,可以方便地获取关联数据。例如,定义一个`hasMany`关系: ```php public function posts() { return $this-&gt;hasMany(Post::class); } ``` 4. **事件系统**:Eloquent模型...

    Laravel开发-eloquent-postgres-uuids

    本项目"Laravel开发-eloquent-postgres-uuids"专门探讨了如何在PostgreSQL数据库中使用UUID作为Eloquent模型的主键。 首先,我们要了解Eloquent ORM,它是Laravel框架的核心部分,为开发者提供了简洁、优雅的方式来...

    Eloquent-Relationships-Advanced-Laravel-7-and-MySQL:Laravel和MySQL开发软件

    应用使用邮递员,失眠等用法$ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-Relations-Laravel-7-and-MySQL[NAME APP]$ composer install$ copy .env.example .env$ php artisan key:generate$ ...

    Laravel开发-eloquent-mongodb-repository

    "Laravel开发-eloquent-mongodb-repository"的主题就是关于如何在Laravel中利用Eloquent ORM来与MongoDB进行交互的实践教程。 首先,我们需要安装Jenssegers/Laravel-MongoDB扩展包,这个扩展提供了Eloquent模型对...

    Laravel开发-laravel-eloquent-filter

    Eloquent Filter是Laravel社区中广泛使用的一个扩展,它允许我们根据输入的筛选器动态地对Eloquent查询进行过滤,从而实现更加灵活的数据检索功能。本文将深入探讨Laravel Eloquent Filter的相关知识点,帮助开发者...

    Eloquent-ORM-Laravel-8.5-Relationships-Advanced:具有Laravel和MySQL的应用程序软件

    $ git clone https://github.com/DanielArturoAlejoAlvarez/Eloquent-ORM-Laravel-8.5-Relationships-Advanced[NAME APP] $ composer install $ copy .env.example .env $ php artisan key:generate $ php artisan ...

Global site tag (gtag.js) - Google Analytics