首頁 > php框架 > Laravel > 主體

關於laravel解決mysql only_full_group_by問題

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

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

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

解決想法

查看sql_mode

select @@GLOBAL.sql_mode;SELECT @@SESSION.sql_mode
登入後複製



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

[mysqld]sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
登入後複製

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

[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

$result = \DB::select('SELECT @@GLOBAL.sql_mode');
print_r($result);exit;
结果:
STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

$result = \DB::select('SELECT @@SESSION.sql_mode');
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 問題順利解決###
'strict' => false,
登入後複製
######這樣可以解決問題,但本著技術就是要搞清楚到底是咋寫的,也並不想直接給他設定為false,#########在vendor/laravel/framework/src/ILLuminate/Database 資料夾下搜尋strict ,直接找到核心程式碼######檔案:vendor/laravel/ framework/src/ILLuminate/Database/Connectors/MySqlConnector.php###
protected function setModes(PDO $connection, array $config){
    if (isset($config['modes'])) {
        $this->setCustomModes($connection, $config);
    } elseif (isset($config['strict'])) {
        if ($config['strict']) {
            $connection->prepare($this->strictMode($connection))->execute();
        } else {
            $connection->prepare("set session sql_mode='NO_ENGINE_SUBSTITUTION'")->execute();
        }
    }}
登入後複製
###第一個判斷直接判斷是否存在modes 配置,有的話就直接用這個######來,搞一下## #
'modes' => ['STRICT_TRANS_TABLES', 'NO_ZERO_IN_DATE', 'NO_ZERO_DATE', 'ERROR_FOR_pISION_BY_ZERO', 'NO_AUTO_CREATE_USER', 'NO_ENGINE_SUBSTITUTION'],
登入後複製
###測試,直接問題搞定######本著尋根刨底的精神,再接著往下看######如果strict = true######將直接設定程式中寫死的sql_mode, laravel 區分了mysql 8.0.11 和別的版本###
protected function strictMode(PDO $connection)
{
    if (version_compare($connection->getAttribute(PDO::ATTR_SERVER_VERSION), '8.0.11') >= 0) {
        return "set session sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'";
    }

    return "set session sql_mode='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'";
}
登入後複製
###再接著如果strict = false ,直接將sql_mode 設定為NO_ENGINE_SUBSTITUTION###
$connection->prepare("set session sql_mode='NO_ENGINE_SUBSTITUTION'")->execute();
登入後複製
###到這裡問題就徹底解決了######最終解決方式###
'strict' => true,
'modes' => ['STRICT_TRANS_TABLES', 'NO_ZERO_IN_DATE', 'NO_ZERO_DATE', 'ERROR_FOR_DIVISION_BY_ZERO', 'NO_AUTO_CREATE_USER', 'NO_ENGINE_SUBSTITUTION'],
登入後複製
###保留了strict = true,增加modes 選項,裡面的參數是laravel 底層的配置,只是去掉了ONLY_FULL_GROUP_BY############ #總結:走了不少彎路,也花了不少時間,最終問題解決,並且不需要修改mysql 的任何配置###

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

相關標籤:
來源:learnku.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!