[解決済み] MySQLの グループ関数の無効な使用
2022-01-28 18:36:27
質問
MySQLを使用しています。以下は私のスキーマです。
仕入先( sid: 整数 名前: 文字列, 住所: 文字列)
部品( pid: 整数 , pname: 文字列, color: 文字列)
カタログ( sid: 整数, pid: 整数 コスト: 実数)
(主キーは太字)
少なくとも2つのサプライヤーによって製造されたすべての部品を選択するクエリを作成しようとしています。
-- Find the pids of parts supplied by at least two different suppliers.
SELECT c1.pid -- select the pid
FROM Catalog AS c1 -- from the Catalog table
WHERE c1.pid IN ( -- where that pid is in the set:
SELECT c2.pid -- of pids
FROM Catalog AS c2 -- from catalog
WHERE c2.pid = c1.pid AND COUNT(c2.sid) >= 2 -- where there are at least two corresponding sids
);
まず、このやり方は正しいのだろうか?
次に、このエラーが発生します。
1111 - グループ関数の無効な使用
何が間違っているのでしょうか?
どうすればいいですか?
を使用する必要があります。
HAVING
ではなく
WHERE
.
違いは、以下の通りです。
WHERE
節は、MySQL が選択する行をフィルタリングします。
次に
MySQL は行をグループ化し、その数値を集計して
COUNT
関数を使用します。
HAVING
は、まるで
WHERE
ただ、それが起こるのは
後
その
COUNT
の値は計算されているので、期待通りに動作するはずです。サブクエリを次のように書き換えてください。
( -- where that pid is in the set:
SELECT c2.pid -- of pids
FROM Catalog AS c2 -- from catalog
WHERE c2.pid = c1.pid
HAVING COUNT(c2.sid) >= 2)
関連
-
[解決済み】MySQLユーザーDBにパスワードカラムがない - OSXへのMySQLインストール
-
[解決済み】MySQL 派生テーブルはすべて独自のエイリアスを持つ必要があります。
-
[解決済み] MySQLで週単位でグループ化する方法は?
-
[解決済み] whereステートメントによるmysqlの一括更新
-
[解決済み] MySQLから最後のN行を選択する
-
[解決済み] SQLSTATE[22003]: 数値の範囲外: 1264 範囲外の値です。
-
[解決済み] MySQLでdatetimeとtimestampのどちらのデータ型を使用すべきですか?
-
[解決済み] MySQLでコマンドラインを使用してSQLファイルをインポートするにはどうすればよいですか?
-
[解決済み] 各GROUP BYグループの最初の行を選択しますか?
-
[解決済み] 各グループの最後のレコードを取得する - MySQL
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】autoカラムは1つしか存在できない
-
[解決済み】SQL文が動作しない-「オペランド型の衝突:dateはintと互換性がない」。
-
[解決済み】MySQLの「ロックを取得しようとしたときにデッドロックが見つかりました。トランザクションを再起動してみてください」を回避する方法
-
[解決済み] MySQLの グループ関数の無効な使用
-
[解決済み] MySQLで「一意のテーブル/エイリアスでない」場合
-
[解決済み] テーブル 'performance_schema.session_variables' は存在しません。
-
[解決済み] テーブルのストレージエンジンは修復をサポートしていません。InnoDB または MyISAM?
-
[解決済み] MySQL エラー 1241。オペランドには1つのカラムが含まれている必要があります。
-
[解決済み] テーブルがクラッシュしたと判定されたため、修復する必要があります。
-
[解決済み] エラー 2005 (hy000)。Google Cloud SQL クライアントの MySQL サーバーホスト '[35.232.51.216]' (0) が不明です。