dongyuxin5353 2016-06-07 14:35
浏览 21
已采纳

Yii范围与多表关系

I have a model Order with one-to-many relationship to model Booking. Booking model, in turn, has a Connection model reference.

I'm having trouble figuring out how to scope out Order so that I only get the order that have bookings with Connection.isDefault value set to 0.

I may have many Bookings with the Order, so I need to look through the very first booking.

I feel this may not be achievable through the scope mechanism as I cannot pass Order/Booking primary keys through helper functions that can be used in scope. What is an alternative workaround here (if any) can you suggest?

The Order has a code for scopes: public function scopes() { return array( 'canView' => array( 'with' => array( 'agency' => array( 'scopes' => array('myNetwork', 'myCompany' => 'OR') ) ), ), 'canEdit' => array( 'with' => array( 'agency' => array( 'scopes' => array('myNetwork', 'myCompany' => 'OR') ), ), ), ); }

  • 写回答

2条回答 默认 最新

  • duanhuoyao7011 2016-06-28 11:17
    关注

    Please try using CDbCriteria(). add relation in Bookings table and order table.

    The Bookings has a code for relation:

    class Bookings extends CActiveRecord{
    
        public function relations() {
        // NOTE: you may need to adjust the relation name and the related
        // class name for the relations automatically generated below.
    
            return array(
                'connectionRel' => array(self::BELONGS_TO, 'connection', 'booking_id', "condition" => 'isDefault = 0'),
            );
        }
    }
    

    The Order has a code for relation:

    class Order extends CActiveRecord{
    
        public function relations() {
        // NOTE: you may need to adjust the relation name and the related
        // class name for the relations automatically generated below.
    
            return array(
                'bookingsRel' => array(self::BELONGS_TO, 'Bookings', 'booking_id', "with" => array('connectionRel')),
            );
        }
    }
    

    Find all order with booking relation :

    Order::model()->with('bookingsRel')->findAll();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写
  • ¥20 Qcustomplot缩小曲线形状问题
  • ¥15 企业资源规划ERP沙盘模拟
  • ¥15 树莓派控制机械臂传输命令报错,显示摄像头不存在
  • ¥15 前端echarts坐标轴问题