Mysql を 5.7 にアップグレードした後のグループ クエリの問題を解決する

Mysql を 5.7 にアップグレードした後のグループ クエリの問題を解決する

問題を見つける

最近MySQLをMySQL 5.7にアップグレードした後、次のようなクエリでグループ化を実行すると、

SELECT *, count(id) as count FROM `news` GROUP BY `group_id` ORDER BY `inputtime` DESC LIMIT 20

次のエラーが報告されます:

SELECT リストは GROUP BY 句内になく、GROUP BY 句内の列に機能的に依存しない非集計列 'news.id' が含まれています。これは sql_mode=only_full_group_by と互換性がありません。

原因分析

その理由は、mysql 5.7 モードにあります。 ONLY_FULL_GROUP_BY はデフォルトで有効になっています。

ONLY_FULL_GROUP_BY は MySQL が提供する sql_mode であり、SQL ステートメントの GROUP BY 句の有効性をチェックするために使用されます。

http://dev.mysql.com/doc/refman/5.7/en/sql-mode.html#sqlmode_only_full_group_by

これはthis is incompatible with sql_mode=only_full_group_by 。完全なグループ化のみ、つまり、実行中に最初にグループ化し、次に照会されたフィールド (選択されたフィールド) に従ってグループ内のフィールドを取り出します。したがって、照会されたすべてのフィールドは、グループ化条件によってグループ化される必要があります。例外が 1 つあり、照会されたフィールドに集計関数が含まれている場合は、上記の count(id) と同様に、グループ化に含める必要はありません。

後で、並べ替え条件の「順序」フィールドもグループ化に含まれている必要があり、並べ替えフィールドもグループ化フィールドから取得されることが分かりました。 わからなかったら行って見てください。

解決:

1. set@@sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

SQL を正常に実行するには、ONLY_FULL_GROUP_BY を削除します。

2. ONLY_FULL_GROUP_BY が選択されていない場合は、選択フィールドがすべてグループ化条件に含まれている必要があります (関数を含むフィールドを除く)。 (この問題が order by に遭遇したときにも発生する場合は、同様に、order by フィールドも group by に含まれている必要があります)。

3. ANY_VALUE()関数を使用する https://dev.mysql.com/doc/refman/5.7/en/miscellaneous-functions.html#function_any-value

この関数は、ONLY_FULL_GROUP_BY SQL モードが有効になっている場合の GROUP BY クエリで役立ちます。これは、MySQL が、有効であるとわかっているクエリを MySQL が判断できない理由で拒否する場合に便利です。関数の戻り値と型は、その引数の戻り値と型と同じですが、関数の結果は ONLY_FULL_GROUP_BY SQL モードではチェックされません。

上記のSQL文は次のように記述できます。

SELECT ANY_VALUE(id) as id、ANY_VALUE(uid) as uid、ANY_VALUE(username) as username、ANY_VALUE(title) as title、ANY_VALUE(author) as author、ANY_VALUE(thumb) as thumb、ANY_VALUE(description) as description、ANY_VALUE(content) as content、ANY_VALUE(linkurl) as linkurl、ANY_VALUE(url) as url、ANY_VALUE(group_id) as group_id、ANY_VALUE(inputtime) as inputtime、count(id) as count FROM `news` GROUP BY `group_id` ORDER BY ANY_VALUE(inputtime) DESC LIMIT 20

私は3番目の方法を選択しました。

要約する

上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM を応援していただきありがとうございます。

以下もご興味があるかもしれません:
  • グループ統計のためにデータテーブルで groupby を使用する方法
  • グループ化された集計クエリには Sequelize の group by を使用する
  • MySQL の高度なクエリとコレクションによるグループ化の紹介
  • MySQL の分析: 単一テーブルを区別し、複数テーブルをグループ化して重複レコードを削除するクエリ
  • group by 統計をグループ化し、特定の期間でクエリを実行します (推奨)

<<:  Linux 編集の開始、停止、再起動の Springboot jar パッケージ スクリプトの例

>>:  ボタンの権限判定を実装するためのVueカスタムv-has命令

推薦する

IE8でラベルの背景画像が表示されない問題の解決方法

今日、ちょっとした問題に遭遇し、長い間苦労しました。そのことを皆さんにシェアしたいと思います。 a ...

MySQLのlike演算子の詳細

1. はじめに不明な値または部分的に既知の値をフィルタリングする場合は、like 演算子を使用でき...

さようなら Docker: 5 分で Containerd に移行する方法

Docker は非常に人気のあるコンテナ技術です。K8S によって廃止され、別のコンテナ技術である ...

MySQL で重複を削除するには、distinct または group by を使用する必要がありますか?

序文group by と distinctive のパフォーマンス比較について: インターネット上の...

Vueテクノロジーに基づく再帰コンポーネントの実装方法

説明するこの記事では、Vue テクノロジーに基づいて再帰コンポーネントを実装する方法を紹介します。 ...

CocosCreator でカメラトラッキングに cc.follow を使用する方法

Cocos Creator バージョン: 2.3.4デモのダウンロード: https://files...

XML構文の詳細な説明

1. 文書化ルール1. 大文字と小文字が区別されます。 2. 属性値は引用符(一重引用符または二重引...

Navicat でストアド プロシージャ、トリガーを作成し、カーソルを使用する簡単な例 (画像とテキスト)

1. テーブルを作成する<br /> まず、2 つのテーブル (users テーブルと...

Vueコンポーネントの7つの通信方法についての深い理解

目次1. props/$emit導入コードサンプル2.Vスロット導入コードサンプル3.$refs/ ...

Dockerでnginxを実行し、ローカルディレクトリをイメージにマウントする方法

1 hupからイメージを取得する docker プル nginx 2 マウントするディレクトリを作成...

MySQLクエリ条件のnot inとinの違いと理由

まずSQLを書く SELECT DISTINCT from_id タラから cod.from_id ...

MySQL 圧縮版 zip のインストールに関する問題の解決策

本日、MySQLの圧縮版をインストールする際に問題が発生しました。サービスが起動できず、2、3時間苦...

ウェブページ制作と饅頭の関係(体験の共有)

昨日は遅くまで寝ていて、一日中起きていました。私の年齢では、夜更かしして本を書くのはもう無理のようで...

基本的なウェブページパフォーマンス最適化ルールの簡単な概要

ブラウザのウェブページを最適化するためのいくつかのルールページの最適化静的リソース圧縮ビルド ツール...

MySQL テーブルスペースとは何ですか?

今日皆さんにお伝えしたいトピックは、「皆さんがよく話題にするテーブル スペースとは一体何でしょうか。...