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

[size=x-large]我的Eloquent单独使用系列文章[/size]
[url=http://xieye.iteye.com/blog/2382907]php的db类库Eloquent单独使用系列(1)[/url]
[url=http://xieye.iteye.com/blog/2383390]php的db类库Eloquent单独使用系列(2) - 分页[/url]
[url=http://xieye.iteye.com/blog/2387809]php的db类库Eloquent单独使用系列(3) - sql日志[/url]
[url=http://xieye.iteye.com/blog/2387983]php的db类库Eloquent单独使用系列(4)- 事件监听[/url]
[url=http://xieye.iteye.com/blog/2383466]php的db类库Eloquent单独使用系列(5)- 模型转数组[/url]
[url=http://xieye.iteye.com/blog/2388023]php的db类库Eloquent单独使用系列(6)- 一对一关联[/url]
[url=http://xieye.iteye.com/blog/2388029]php的db类库Eloquent单独使用系列(7)- 一对多关联[/url]
[url=http://xieye.iteye.com/blog/2388150]php的db类库Eloquent单独使用系列(8)- 多对多关联[/url]
[url=http://xieye.iteye.com/blog/2388162]php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身[/url]
[url=http://xieye.iteye.com/blog/2388280]php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多[/url]
[url=http://xieye.iteye.com/blog/2388521]php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性[/url]
[url=http://xieye.iteye.com/blog/2389182]php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2[/url]


本系列文章的目的就是脱离laravel环境使用Eloquent,因为它[b]好用[/b]。
本系列文章所有代码均测试通过。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)
);


[size=x-large]源代码[/size]
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!';
}
}


[size=x-large]浏览器输出[/size]
[img]http://dl2.iteye.com/upload/attachment/0126/4052/28afc2c7-34ba-387e-9eb8-139785420a00.png[/img]

[size=x-large]总结:[/size]
结果集中多了一个字段 country_id ,好神奇!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值