問題を見つける 最近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 これは 後で、並べ替え条件の「順序」フィールドもグループ化に含まれている必要があり、並べ替えフィールドもグループ化フィールドから取得されることが分かりました。 わからなかったら行って見てください。 解決: 1. SQL を正常に実行するには、ONLY_FULL_GROUP_BY を削除します。 2. ONLY_FULL_GROUP_BY が選択されていない場合は、選択フィールドがすべてグループ化条件に含まれている必要があります (関数を含むフィールドを除く)。 (この問題が order by に遭遇したときにも発生する場合は、同様に、order by フィールドも group by に含まれている必要があります)。 3. この関数は、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 を応援していただきありがとうございます。 以下もご興味があるかもしれません:
|
<<: Linux 編集の開始、停止、再起動の Springboot jar パッケージ スクリプトの例
>>: ボタンの権限判定を実装するためのVueカスタムv-has命令
1つ。 wget https://dev.mysql.com/get/mysql57-communi...
<br />原文: http://andymao.com/andy/post/104.h...
JavaScript の hasOwnProperty() メソッドは、Object のプロトタイ...
CSS でテキストを中央揃えにするプロパティは非常に簡単に実現できます。text-align:cen...
前提条件1. ローカルコンピュータとサーバーにDockerがインストールされています。ダウンロード方...
仮想マシンをインストールするときに、「VMware ワークステーションはデバイス/資格情報ガードと互...
考えられる解決策1. Math.randomは[0,1)の範囲の乱数を生成します。 //今回は生成さ...
目次序文: 1. ロック待機とデッドロックを理解する2. 現象の再発と治療要約:序文: MySQL ...
目次導入インストールと使用方法文章の相違点と類似点の簡単な比較VuexとPiniaの長所と短所Pin...
nohup コマンドUnix/Linux を使用する場合、通常はプログラムをバックグラウンドで実行す...
目次1. 暗黙的な変換二重等号での変換ブール型変換「+」と「-」 2. 強制型変換' ...
まずは適用方法を説明します。nginxモジュールにはjtxyとjtcmdの2つがあります。 http...
1. 50と93では鏡像が消える [root@h50 /]# df -h ファイルシステムの使用済み...
HTML フォームは、さまざまな種類のユーザー入力を収集するために使用されます。次のコードは、HTM...
序文<router-link> タグは、Vue アプリ内のさまざまなページ間を移動するた...