webees

webees

这家伙有点懒,还没写个性签名!

  • 财富值180
  • 威望值10
  • 总积分380

个人信息

  • 2015-06-12 已签到
    连续签到1天,获得了5个金钱
  • 2015-06-10 已签到
    连续签到2天,获得了10个金钱
  • 回复了 的回答

    数据库配置中开启表结构缓存 就没了。

    我补充下:如果配置了该项,可能在修改表结构时出现程序异常,建议部署到服务器时再配置。

    db=>[
      'enableSchemaCache' => true,
    ]
    
  • 回复了 的回答

    如果你在class Order里定义了一个class Customer的关联(如order表里有一个customer_id的字段),在创建Order记录的时候,可能会有类似这样的执行:

    $order = new Order();
    $order->customer_id = $customer->id;
    $order->save();
    

    如果在Order类里定义过外键关联(如下),那就可以通过link方法用面向对象的方式来给customer_id赋值:

    public function getCustomer()
    {
        return $this->hasOne(Customer::className(), ['id' => 'customer_id']);
    }
    

    之前创建Order对象的语句就变成:

    $order = new Order();
    $order->link('customer', $customer); // $order和$customer不能都是新创建的对象
    

    这里link的作用只是将外键的值填到对应字段,但如果外键关联是通过中间表来实现的,那link会自动创建中间表记录。比如
    有order表,item表,order_item表来存储order和item的关联。参考Relations via a Junction Table

    如果在Order类里定义过外键关联如下:

    public function getItems()
    {
        return $this->hasMany(Item::className(), ['id' => 'item_id'])
            ->viaTable('order_item', ['order_id' => 'id']);
    }
    

    那就可以通过link方法来关联Item对象:

    $order = new Order();
    $order->link('items', $item);
    

    order_item表中会自动创建一条order_id为$order->id, item_id为$item->id的记录

    感谢,还得再深入研究下。

  • 2015-06-09 已签到
    连续签到1天,获得了5个金钱
  • 2015-06-07 已签到
    连续签到1天,获得了5个金钱
  • 提出了问题
    yii\db\ActiveRecord::link()怎么用的?
见习主管 等级规则
380/500
资料完整度
30/100
用户活跃度
20/100

Ta的关注

0

Ta的粉丝

5

Ta的访客

10