ホームページ >データベース >mysql チュートリアル >「オペランドには 1 列を含める必要があります」という MySQL エラーを修正する方法は?

「オペランドには 1 列を含める必要があります」という MySQL エラーを修正する方法は?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2025-01-12 15:27:43843ブラウズ

How to Fix the

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 サイトの他の関連記事を参照してください。

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