Zend_db 联结表联接查询
Posted
技术标签:
【中文标题】Zend_db 联结表联接查询【英文标题】:Zend_db junction table join query 【发布时间】:2010-02-07 23:49:47 【问题描述】:不知道为什么我无法弄清楚这一点。基本上,我有两个具有多对多关系的表,所以我在它们之间有一个联结表。
例如,考虑以下数据库架构:
Restaurant (id, restaurant_name, suburb)
RestaurantCuisine (restaurant_id, cuisine_id)
Cuisine (id, cuisine_name)
所以,很多餐厅可以有很多美食。
我尝试构建的查询将返回郊区存在的所有美食。一个SQL示例如下:
SELECT cuisine_name
FROM CuisineRestaurant
JOIN Cuisine ON Cuisine.id = CuisineRestaurant.cuisine_id
JOIN Restaurant ON Restaurant.id = CuisineRestaurant.restaurant_id
WHERE suburb LIKE '%x%';
这对我来说似乎很有意义。
如何使用 Zend_Db 实现这一点?
【问题讨论】:
到目前为止你尝试了什么? 嗨,戈登,经过多次反复试验,我想出了这个。它返回正确的数据,但似乎运行得很慢: $select = $this->select() ->setIntegrityCheck(false) ->distinct() ->from('CuisineRestaurant', array()) ->join( 'Cuisine', 'Cuisine.id = CuisineRestaurant.cuisine_id', array('id', 'cuisine')) ->join('Restaurant', 'Restaurant.id = CuisineRestaurant.restaurant_id', array()) ->where ('Restaurant.suburb = ?', $suburb) ->order('Cuisine.cuisine'); 【参考方案1】:这是 Zend_Db_Select 查询版本:
$select = Zend_Db_Table::getDefaultAdapter()->select();
$select->from('RestaurantCuisine', 'cuisine_name')
->join('Cuisine', 'Cuisine.id = RestaurantCuisine.cuisine_id', array())
->join('Restaurant', 'Restaurant.id = RestaurantCuisine.restaurant_id', array())
->where('suburb LIKE ?', '%x%');
结果:
选择“餐厅美食”。“美食名称” 来自“餐厅美食” 内部加入“Cuisine”ON Cuisine.id = RestaurantCuisine.cuisine_id 在 Restaurant.id = RestaurantCuisine.restaurant_id 上的内部加入“餐厅” WHERE(郊区 LIKE '%x%')
您说查询运行缓慢。您是否正确配置了主键和索引?
【讨论】:
非常感谢 Luiz。我很快就会试试这个。我对所有可搜索和连接的字段都有索引。 您的解决方案有效。缓慢的查询是由于我正在开发的服务器。我已经搬到了一个新的服务器上,它的速度非常快。谢谢路易斯。【参考方案2】:我遇到了同样的问题,像这样的查询运行很慢,我认为问题在于 zend 是如何制作的。
$select = Zend_Db_Table::getDefaultAdapter()->select();
$select = Zend_Db_Table::getDefaultAdapter()->select();
$select->from('RestaurantCuisine', 'cuisine_name')
->join('Cuisine', 'Cuisine.id = RestaurantCuisine.cuisine_id', array())
->join('Restaurant', 'Restaurant.id = RestaurantCuisine.restaurant_id', array())
->where('suburb LIKE ?', '%x%');
【讨论】:
以上是关于Zend_db 联结表联接查询的主要内容,如果未能解决你的问题,请参考以下文章