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

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

    博客分类:
  • 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

本文的目的是使用一对多关联。
首先建表,users是用户表,moneys是帐号表,一个用户有多个帐户。
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 moneys (
  id int(11) NOT NULL AUTO_INCREMENT,
  user_id int not null default 0 comment '用户id主键',
  cny int NOT NULL DEFAULT '0' COMMENT '人民币',
  usd int NOT NULL DEFAULT '0' COMMENT '美元',
  PRIMARY KEY (id)
);


源代码
本文3个文件,主程序,user模型类,money模型类

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

/**
 * User模型类
 */
class User extends Model 
{
    protected $table = 'users';
    public $timestamps = false;
    
    public function money()
    {
        // 重要说明:user_id是Money模型里的,id是User模型里的。
        return $this->hasMany('app\model\Money', 'user_id', 'id');
    }
}


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

/**
 * 账户模型类
 */
class Money extends Model 
{
    protected $table = 'moneys';
    public $timestamps = false;
    
    public function user()
    {
        // 重要说明:user_id是Money模型里的,id是User模型里的。
        return $this->belongsTo('app\model\User', 'user_id', 'id');
    }
}


主程序
<?php
namespace app\control;

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

class Ill2
{
    /**
     * 主程序。
     */
    public function hook() 
    {
        $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 moneys ');
        
        $user = new User ();
        $user->name = 'user1';
        $user->id = 1;
        $user->save (); // 新模型添加
        $user = new User ();
        $user->name = 'user2';
        $user->id = 2;
        $user->save (); // 新模型添加
        
        $money = new Money();
        $money->id = 1;
        $money->cny = 10;
        $money->usd = 20;
        $money->user_id = 2;
        $money->save (); // 新模型添加
        
        $money = new Money();
        $money->id = 2;
        $money->cny = 1000;
        $money->usd = 1000;
        $money->user_id = 2;
        $money->save (); // 新模型添加
        
        
        // 要点:调用money方法时,不要加括号
        $moneys = User::find(2)->moneys;
        echo "帐号模型数据集合:". $moneys->toJson() ;
        echo '<br>';
        $user  = Money::find(1)->user;
        echo "用户模型数据:". $user->toJson()  ;
        echo '<br>';
        
        echo "<h2>使用查询构建器</h2>";
        $moneys = User::find(2)->moneys()->where("cny","<",1000)->get();
        echo "帐号模型数据集合:". $moneys->toJson() ;
        echo '<br>all ok!';
    }
}


输出结果
以下是浏览器输出
帐号模型数据集合:[{"id":1,"user_id":2,"cny":10,"usd":20},{"id":2,"user_id":2,"cny":1000,"usd":1000}]
用户模型数据:{"id":2,"name":"user2","age":0}

使用查询构建器
帐号模型数据集合:[{"id":1,"user_id":2,"cny":10,"usd":20}]
all ok!


总结
  • 表结构没有任何变化。
  • 账户模型类与前文相同,用户模型类略改,hasOne改成hasMany
  • 主程序增加了使用查询构建器筛选的重要功能
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics