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 联结表联接查询的主要内容,如果未能解决你的问题,请参考以下文章

啥是左外部联结?

联表操作

数据库(比如MYSQL) ,表连结查询与子查询哪个效率高些? 为啥

联接表中的 JPQL 查询

数据库查询·联接思维导图&要点&误点(含示例)

Mysql表连接查询