1

なぜこれを理解できないのかわかりません。基本的に、多対多の関係を持つ 2 つのテーブルがあるため、その間にジャンクション テーブルがあります。

たとえば、次のデータベース スキーマを考えてみましょう。

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 を使用してこれを実装するにはどうすればよいですか?

4

2 に答える 2

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%');

結果:

SELECT "RestaurantCuisine"."cuisine_name"
FROM "RestaurantCuisine"
INNER JOIN "Cuisine" ON Cuisine.id = RestaurantCuisine.cuisine_id
INNER JOIN "Restaurant" ON Restaurant.id = RestaurantCuisine.restaurant_id
WHERE (郊外 LIKE '%x%')

あなたは、クエリの実行が遅いと言いました。主キーとインデックスが正しく構成されていますか?

于 2010-02-09T11:12:50.960 に答える
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%');  
于 2013-10-25T05:04:12.160 に答える