PostgreSQL と MySQL: GROUP BY 句の比較
MySQL クエリを PostgreSQL に移行すると、「列 'XYZ' は GROUP BY 句に表示されるか、集計関数で使用される必要があります。」というエラーが発生する可能性があります。この矛盾は、これらのデータベースが GROUP BY
句を処理する方法に起因します。
MySQL の非標準的なアプローチ
MySQL の GROUP BY
実装は SQL 標準から逸脱しています。 GROUP BY
句に明示的にリストされていない列を選択できるため、予測できない出力が発生します。 各グループから選択された行は、インデックス作成やクエリの最適化などの要素の影響を受けて、暗黙的に決定されます。
PostgreSQL の標準準拠 GROUP BY
しかし、PostgreSQL は SQL 標準に厳密に従っています。 SELECT
リスト内のすべての列は、GROUP BY
句に含めるか、集計関数 (SUM
、AVG
、COUNT
など) の一部である必要があります。 そうしないと、前述のエラーが発生します。
PostgreSQL での MySQL の動作の複製
PostgreSQL のアプローチはより予測可能で標準に準拠していますが、DISTINCT ON
を使用して MySQL の非標準的な動作をシミュレートできます。次の PostgreSQL クエリはこれを示しています:
SELECT DISTINCT ON (availables.bookdate) availables.*, rooms.hotel_id FROM availables INNER JOIN rooms ON rooms.id = availables.room_id WHERE rooms.hotel_id = 5056 AND availables.bookdate BETWEEN '2009-11-22' AND '2009-11-24' ORDER BY availables.updated_at;
DISTINCT ON
は、availables.bookdate
句で指定された行の順序を維持しながら、ORDER BY
内の個別の値ごとに 1 つの行を返します。 これは、この特定のシナリオにおける MySQL の非標準 GROUP BY
動作を効果的に模倣します。 このアプローチは、ORDER BY
句に依存して、個別のグループごとにどの行が選択されるかを定義することに注意してください。
以上がPostgreSQL で MySQL GROUP BY クエリが失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、MySQLの「共有ライブラリを開くことができない」エラーについて説明します。 この問題は、必要な共有ライブラリ(.so/.dllファイル)を見つけることができないMySQLの障害に起因しています。ソリューションには、システムのパッケージMを介してライブラリのインストールを確認することが含まれます。

この記事では、DockerのMySQLメモリ使用量を最適化することを調査します。 監視手法(Docker統計、パフォーマンススキーマ、外部ツール)および構成戦略について説明します。 これらには、Dockerメモリの制限、スワッピング、およびcgroupsが含まれます

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

この記事では、PHPMyAdminの有無にかかわらず、LinuxにMySQLを直接インストールするのとPodmanコンテナを使用します。 それは、各方法のインストール手順を詳述し、孤立、携帯性、再現性におけるポッドマンの利点を強調しますが、

この記事では、自己完結型のサーバーレスリレーショナルデータベースであるSQLiteの包括的な概要を説明します。 SQLiteの利点(シンプルさ、移植性、使いやすさ)と短所(同時性の制限、スケーラビリティの課題)を詳しく説明しています。 c

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

このガイドは、HomeBrewを使用してMacOSに複数のMySQLバージョンをインストールおよび管理することを示しています。 Homebrewを使用して設置を分離し、紛争を防ぐことを強調しています。 この記事では、インストール、開始/停止サービス、および最高のPRAを詳述しています

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

WebStorm Mac版
便利なJavaScript開発ツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ホットトピック









