欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

php的db类库Eloquent单独使用系列(10)- 远程一对多

程序员文章站 2022-03-06 22:25:47
...
我的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 countries (
  id int(11) NOT NULL AUTO_INCREMENT,
  name varchar(50)  NOT NULL DEFAULT '' COMMENT '国家名称',
  PRIMARY KEY (id)
);


CREATE TABLE users (
  id int(11) NOT NULL AUTO_INCREMENT,
  name varchar(50)  NOT NULL DEFAULT '' COMMENT '用户名称',
  country_id int(11) NOT NULL DEFAULT '0' COMMENT '国家id',
  PRIMARY KEY (id)
);

create table posts (
  id int(11) NOT NULL AUTO_INCREMENT,
  user_id int  NOT NULL DEFAULT '0' COMMENT '用户id',
  title varchar(255) not null default '' comment '文章标题',
  PRIMARY KEY (id)
);


源代码
Country.php 国家模型类
<?php
namespace app\model\ill5;
use \Illuminate\Database\Eloquent\Model;

/**
 * 国家模型类
 */
class Country extends Model 
{
    protected $table = 'countries';
    public $timestamps = false;
    
    /**
     * 获取指定国家的所有文章
     */
    public function posts()
    {
        //当执行这种关联查询时通常 Eloquent 外键规则会被使用,如果你想要自定义该关联关系的外键,
        //可以将它们作为第三个、第四个参数传递给hasManyThrough 方法。第三个参数是中间模型的外键名,
        //第四个参数是最终模型的外键名,第五个参数是本地主键。
        return $this->hasManyThrough('app\model\ill5\Post', 'app\model\ill5\User', 'country_id', 'user_id', 'id');
    }
}


用户模型类User.php
<?php
namespace app\model\ill5;
use \Illuminate\Database\Eloquent\Model;

/**
 * User模型类
 */
class User extends Model 
{
    protected $table = 'users';
    public $timestamps = false;
}


文章模型类
<?php
namespace app\model\ill5;
use \Illuminate\Database\Eloquent\Model;

/**
 * Post模型类
 */
class Post extends Model 
{
    protected $table = 'posts';
    public $timestamps = false;
}


主程序
<?php
namespace app\control;

use Illuminate\Database\Capsule\Manager;
use app\model\ill5\User;
use app\model\ill5\Country;
use app\model\ill5\Post;

class Ill5
{
    /**
     * 主程序。
     */
    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 posts ');
        $db::delete('delete from countries ');
        
        foreach (range(1,2) as $v) {
            $country = new Country();
            $country->name = '国家'.$v;
            $country->id = $v;
            $country->save (); // 新模型添加
        }
        foreach (range(1,5) as $v) {
            $user = new User ();
            $user->name = '用户'.$v;
            $user->id = $v;
            if ($v< 4) {
                $user->country_id = 1;
            }else {
                $user->country_id = 2;
            }
            $user->save (); // 新模型添加
        }
        foreach (range(1,10) as $v) {
            $post = new Post ();
            $post->title = '文章'.$v;
            $post->id = $v;
            if ($v < 5) {
                $post->user_id = 1;
            }elseif ($v < 9){
                $post->user_id = 2;
            }else  {
                $post->user_id = 5;
            }
            $post->save (); // 新模型添加
        }
        
        echo "<h2>国家1的所有文章</h2>";
        echo Country::find(1)->posts->toJson(JSON_UNESCAPED_UNICODE);
        echo "<br>";
        echo "<h2>国家2的所有文章</h2>";
        echo Country::find(2)->posts->toJson(JSON_UNESCAPED_UNICODE);
        echo "<br>";
        
        echo '<br>all ok!';
    }
}


浏览器输出
php的db类库Eloquent单独使用系列(10)- 远程一对多
            
    
    博客分类: PHP phpormeloquent远程一对多 

总结:
结果集中多了一个字段 country_id ,好神奇!
  • php的db类库Eloquent单独使用系列(10)- 远程一对多
            
    
    博客分类: PHP phpormeloquent远程一对多 
  • 大小: 22.6 KB