hasOne('Customer', array('id' => 'customer_id')); } public function orderItems() { return $this->hasMany('OrderItem', array('order_id' => 'id')); } public function items() { return $this->hasMany('Item', array('id' => 'item_id')) ->via('orderItems')->orderBy('id'); } public function books() { return $this->manyMany('Item', array('id' => 'item_id'), 'tbl_order_item', array('item_id', 'id')) ->where('category_id = 1'); } public function customer() { return $this->hasOne('Customer', array('id' => 'customer_id')); } public function orderItems() { return $this->hasMany('OrderItem', array('order_id' => 'id')); } public function items() { return $this->hasMany('Item') ->via('orderItems', array('item_id' => 'id')) ->order('@.id'); } public function books() { return $this->hasMany('Item') ->pivot('tbl_order_item', array('order_id' => 'id'), array('item_id' => 'id')) ->on('@.category_id = 1'); } }