我有两张桌子order
和order_version
order
| id |
| 1 |
| 2 |
order_version
| id | order_id | status |
| 1 | 1 | 0 |
| 2 | 2 | 0 |
| 3 | 1 | 1 |
| 4 | 1 | 2 |
我想查找所有已更改版本的订单。这意味着我只想获得订单id='1'
,因为另一个没有更改并且只有一个版本。
试过这个:
1) $criteria = new CDbCriteria();
2) $criteria->with = array('orderVersions');
3) $criteria->addCondition("(SELECT MAX(status) FROM order_version) != '0'");
4) $criteria->addInCondition('order.id', $orderArray);
5) $criteria->order = 'order.id DESC';
6) $orders = Order::model()->findAll($criteria);
$orderArray
变量是order
id
s 的数组。
首先问题出在第四行。
Column not found: 1054 Unknown column 'order.id' in 'where clause'
如果我这样做id
而不是order.id
那么我有
Integrity constraint violation: 1052 Column 'id' in where clause is ambiguous.
第 5 行也有同样的问题。
另:我真的不知道如何在yii中使用子查询,这是第3行。
有什么建议么?