• 技术文章 >php框架 >YII

    yii2 hasone怎么用

    (*-*)浩(*-*)浩2019-11-07 09:57:56原创1613
    Yii2中的表之间的关联有2种,它们用来指定两个模型之间的关联。

    一对多:hasMany

    一对一:hasOne (推荐学习:yii教程

    返回结果:这两个方法的返回结果都为yii\db\ActiveQuery对象

    第一个参数:所关联的模型的类名称。

    第二个参数:是一个数组,其中键为所关联的模型中的属性,值为当前模型中的属性。

    关联的使用

    现在我们获取一个客户的所有的订单信息

    $customer = Customer::findOne(1);  
    $orders = $customer->orders; // 通过在Customer中定义的关联方法(getOrders())来获取这个客户的所有的订单。

    上面的两行代码会生成如下sql语句

    SELECT * FROM customer WHERE id=1;  
    SELECT * FROM order WHERE customer_id=1;

    关联结果缓存

    如果客户的订单改变了,我们再重新调用

    $orders = $customer->orders;

    再次得到订单的时候你会发现没有变化。原因是只会在第一次执行$customer->orders的时候才会去数据库里面查询,然后会把结果缓存起来,以后查询的时候都不会再执行sql。

    那么如果我想再次执行sql如何做呢?可以执行

    unset($customer->orders);  
    $customer->orders;

    然后就可以从数据库里面取数据了。

    代码说明:

    // 执行sql语句: SELECT * FROM customer WHERE id=1  
    $customer = Customer::findOne(1);  
    //执行sql:SELECT * FROM order WHERE customer_id=1  
    $orders1 = $customer->orders;  
    //这个不会执行sql,直接使用上面的缓存结果  
    $orders2 = $customer->orders;
    //如果中间的用户订单有变化,我们就不能从缓存中获取,要unset掉
    unset($customer->orders);  
    $orders2 = $customer->orders;

    以上就是yii2 hasone怎么用的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:yii2
    上一篇:yii2如何开启debug 下一篇:yii2是什么
    大前端线上培训班

    相关文章推荐

    • 如何在yii2-wx中使用try_catch• 关于yii2加密和解密的介绍• YII2实现面向方面编程• yii2中user的用法介绍(附代码)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网