首頁 > php框架 > Laravel > 關於laravel解決mysql only_full_group_by問題

關於laravel解決mysql only_full_group_by問題

藏色散人
發布: 2021-01-26 09:10:55
轉載
3215 人瀏覽過

MySQL 5.7 之後only_full_group_by 預設是開啟的,這就導致sql 的檢測更加嚴格,將導致報下面的錯

1

<a href="https://www.php.cn/phpkj/laravel/" target="_blank">SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'edu.t_sounds.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by</a>

解決這個問題也走了不少彎路,按照網路上找的方式一個一個試

解決想法

查看sql_mode

1

select @@GLOBAL.sql_mode;SELECT @@SESSION.sql_mode

登入後複製



##首先查看並修改mysql 配置文件,my.cnf 很尷尬我的這個裡面並沒有ONLY_FULL_GROUP_BY

1

[mysqld]sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

登入後複製

不行,就接著來,想到mysql 有服務端配置,和客戶端配置之分,那就增加[client] 配置

1

[client]sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

登入後複製

重啟mysql ,在MySQL工具查看sql_mode,確實顯示結果和配置的是一樣的,但是程式仍然報同樣的錯

又是一番查找,突然意識到global session 的問題,也就是文章頭放的兩條查詢sql_mode 的語句,就查詢一下是啥區別

mysql 變數設置方式分兩種,

一種全域配置,也就是global,作用於全域;

一種會話配置session, 只作用於目前連接

會不會是laravel 在目前連線設定了sql_mode

在laravel 程式列印sql_mode

1

2

3

4

5

6

7

8

9

$result = \DB::select(&#39;SELECT @@GLOBAL.sql_mode&#39;);

print_r($result);exit;

结果:

STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

 

$result = \DB::select(&#39;SELECT @@SESSION.sql_mode&#39;);

print_r($result);exit;

结果:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

登入後複製

找到了原來是程式設定了

###第一想到mysql 的配置有嚴格模式,我一直是開啟狀態,設定為false 問題順利解決###

1

&#39;strict&#39; => false,

登入後複製
######這樣可以解決問題,但本著技術就是要搞清楚到底是咋寫的,也並不想直接給他設定為false,#########在vendor/laravel/framework/src/ILLuminate/Database 資料夾下搜尋strict ,直接找到核心程式碼######檔案:vendor/laravel/ framework/src/ILLuminate/Database/Connectors/MySqlConnector.php###

1

2

3

4

5

6

7

8

9

10

protected function setModes(PDO $connection, array $config){

    if (isset($config[&#39;modes&#39;])) {

        $this->setCustomModes($connection, $config);

    } elseif (isset($config[&#39;strict&#39;])) {

        if ($config[&#39;strict&#39;]) {

            $connection->prepare($this->strictMode($connection))->execute();

        } else {

            $connection->prepare("set session sql_mode=&#39;NO_ENGINE_SUBSTITUTION&#39;")->execute();

        }

    }}

登入後複製
###第一個判斷直接判斷是否存在modes 配置,有的話就直接用這個######來,搞一下## #

1

&#39;modes&#39; => [&#39;STRICT_TRANS_TABLES&#39;, &#39;NO_ZERO_IN_DATE&#39;, &#39;NO_ZERO_DATE&#39;, &#39;ERROR_FOR_pISION_BY_ZERO&#39;, &#39;NO_AUTO_CREATE_USER&#39;, &#39;NO_ENGINE_SUBSTITUTION&#39;],

登入後複製
###測試,直接問題搞定######本著尋根刨底的精神,再接著往下看######如果strict = true######將直接設定程式中寫死的sql_mode, laravel 區分了mysql 8.0.11 和別的版本###

1

2

3

4

5

6

7

8

protected function strictMode(PDO $connection)

{

    if (version_compare($connection->getAttribute(PDO::ATTR_SERVER_VERSION), &#39;8.0.11&#39;) >= 0) {

        return "set session sql_mode=&#39;ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION&#39;";

    }

 

    return "set session sql_mode=&#39;ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION&#39;";

}

登入後複製
###再接著如果strict = false ,直接將sql_mode 設定為NO_ENGINE_SUBSTITUTION###

1

$connection->prepare("set session sql_mode=&#39;NO_ENGINE_SUBSTITUTION&#39;")->execute();

登入後複製
###到這裡問題就徹底解決了######最終解決方式###

1

2

&#39;strict&#39; => true,

&#39;modes&#39; => [&#39;STRICT_TRANS_TABLES&#39;, &#39;NO_ZERO_IN_DATE&#39;, &#39;NO_ZERO_DATE&#39;, &#39;ERROR_FOR_DIVISION_BY_ZERO&#39;, &#39;NO_AUTO_CREATE_USER&#39;, &#39;NO_ENGINE_SUBSTITUTION&#39;],

登入後複製
###保留了strict = true,增加modes 選項,裡面的參數是laravel 底層的配置,只是去掉了ONLY_FULL_GROUP_BY############ #總結:走了不少彎路,也花了不少時間,最終問題解決,並且不需要修改mysql 的任何配置###

以上是關於laravel解決mysql only_full_group_by問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
Laravel Space/laravel-backup 無法安裝
來自於 1970-01-01 08:00:00
0
0
0
Laravel 5.1 登入 laravel 自備的 沒有啦
來自於 1970-01-01 08:00:00
0
0
0
composer安裝laravel安裝不上
來自於 1970-01-01 08:00:00
0
0
0
為什麼thinkphp比laravel效能好?
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板