ホームページ >データベース >mysql チュートリアル >ページネーションを使用して MySQL JOIN の最新の行のみを効率的に取得するにはどうすればよいですか?

ページネーションを使用して MySQL JOIN の最新の行のみを効率的に取得するにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2025-01-03 13:47:40582ブラウズ

How to Efficiently Retrieve Only the Most Recent Row in a MySQL JOIN with Pagination?

ページネーションを使用した MySQL JOIN でのみ最新の行を取得する

customer_data のような履歴データ テーブルを扱う場合は、結合することが望ましいことがよくあります。最新の行のみを別のテーブルに転送しながら、管理も行いますページネーション。

元のクエリ:

SELECT *, CONCAT(title,' ',forename,' ',surname) AS name
FROM customer c
INNER JOIN customer_data d on c.customer_id=d.customer_id
WHERE name LIKE '%Smith%' LIMIT 10, 20

WHERE 句を使用した最適化された JOIN:

最新のもののみを取得する各顧客の行を作成するには、次の条件を WHERE に追加します。句:

...
WHERE
  d.customer_data_id IN (
    SELECT MAX(customer_data_id)
    FROM customer_data
    WHERE customer_id = c.customer_id
  )
...

代替のインデックス作成ソリューション:

特に負荷の高いクエリでパフォーマンスを向上させるには、customer_data の (customer_id, customer_data_id) 列にインデックスを作成することを検討してください。 。これにより、MySQL は各顧客の最新の行を迅速に識別できるようになります。

インデックスを使用した WHERE 句の例:

...
WHERE
  d.customer_id = c.customer_id AND
  d.customer_data_id = (
    SELECT MAX(customer_data_id)
    FROM customer_data
    WHERE customer_id = c.customer_id
  )
...

LIKE を使用した CONCAT:

はい、CONCAT と LIKE を使用することは、複数のフィールドを検索する有効な方法です一緒に連結されました。これは、元の列にインデックスが付けられておらず、通常はテーブル全体のスキャンが行われる場合に特に便利です。

追加の考慮事項:

  • ページネーション: LIMIT 句と OFFSET 句は、外側のクエリ (つまり、クエリの外側) に適用する必要があります。 subquery).
  • JOIN Type: INNER JOIN は、通常、両方のテーブルから一致する行をすべて取得するのに適しています。ただし、特定のデータ構造に基づいてパフォーマンスを最適化するために、他の JOIN タイプを試してみることもできます。

以上がページネーションを使用して MySQL JOIN の最新の行のみを効率的に取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。