MySQL エラー「オペランドには 1 列を含める必要があります」の解決策
この記事は、MySQL クエリで発生する「オペランドには 1 つの列を含める必要があります」エラーを解決します。このエラーは通常、サブクエリが複数の列を返すのに、外側のクエリでは 1 つの列のみが必要な場合に発生します。
誤解:
「オペランドには 1 列が含まれている必要があります」エラーは、オペランド (ここではサブクエリ) が 1 つの列を返すことを予期していましたが、実際には複数の列を返したために列番号の不一致が発生したことを示します。
問題解決:
この問題は、サブクエリが単一の列のみを返すようにクエリを変更することで解決できます。主に 2 つの方法があります:
1. JOIN を使用します:
サブクエリの使用を避け、JOIN
を直接使用して、users
テーブルを posts
列の posted_by
テーブルに結合します。この方法は、users
テーブル内の特定の列を選択する場合により柔軟です。
<code class="language-sql">SELECT topics.id, topics.name, topics.post_count, topics.view_count, COUNT(posts.solved_post) AS solved_post, users.username AS posted_by, users.id AS posted_by_id FROM topics LEFT OUTER JOIN posts ON posts.topic_id = topics.id LEFT OUTER JOIN users ON users.id = posts.posted_by WHERE topics.cat_id = :cat GROUP BY topics.id</code>
2. サブクエリから 1 つの列を選択します:
または、GROUP BY
句を使用して単一の列のみを返すようにサブクエリを変更することもできます。ただし、複数のユーザーが同じ ID を持っている場合、この方法ではデータが失われる可能性があります。
<code class="language-sql">SELECT topics.id, topics.name, topics.post_count, topics.view_count, COUNT(posts.solved_post) AS solved_post, (SELECT users.username FROM users WHERE users.id = posts.posted_by GROUP BY users.id) AS posted_by FROM topics LEFT OUTER JOIN posts ON posts.topic_id = topics.id WHERE topics.cat_id = :cat GROUP BY topics.id</code>
どの方法を選択するかは、特定のニーズとデータ構造によって異なります。 通常、最初のアプローチ (JOIN を使用) は、より効率的で明確なソリューションです。
以上が「オペランドには 1 列を含める必要があります」という MySQL エラーを修正する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。