不知道为什么我不能解决这个问题。基本上,我有两个具有多对多关系的表,所以我在它们之间有一个联结表。
例如,请考虑以下数据库架构:
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实现此功能?
答案 0 :(得分:3)
这是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%');
结果:
选择“RestaurantCuisine”。“cuisine_name”
来自“RestaurantCuisine”
INNER JOIN“Cuisine”ON Cuisine.id = RestaurantCuisine.cuisine_id
INNER JOIN“餐厅”ON Restaurant.id = RestaurantCuisine.restaurant_id
WHERE(郊区LIKE'%x%')
你说查询运行缓慢。您是否正确配置了主键和索引?
答案 1 :(得分:0)
我遇到了同样的问题,这样的查询运行速度非常慢,我认为问题是由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%');