<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                ~~~ 1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'csc_risk.a.DefaultDate' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by, Time: 0.035000s? ~~~ SELECT VERSION() 查詢數據版本發現確實是5.7版本 原因分析:MySQL5.7版本默認設置了 mysql sql\_mode = only\_full\_group\_by 屬性,導致報錯。 知道原因就好辦: 下載安裝的是最新版的mysql5.7.x版本,默認是開啟了?only_full_group_by?模式的,但開啟這個模式后,原先的?group by?語句就報錯,然后又把它移除了。 一旦開啟?only_full_group_by?,感覺,group by?將變成和?distinct?一樣,只能獲取受到其影響的字段信息,無法和其他未受其影響的字段共存,這樣,group by?的功能將變得十分狹窄了 only_full_group_by?模式開啟比較好。因為在?mysql?中有一個函數:?any_value(field)?允許,非分組字段的出現(和關閉?only_full_group_by?模式有相同效果)。 ## 解決方案一 ### 1、查看sql\_mode SELECT @@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 ### 2、去掉ONLY\_FULL\_GROUP\_BY,重新設置值。 在mysql.ini 里面,如果找不到sql\_mode 則直接放進去[mysqld]里面 sql_mode =STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION ### 3 重啟即可 /etc/init.d/mysql restart lnmp一鍵包的mysql配置有個坑,以為只有一個配置一直改/etc/my.cnf這個文件,一直重啟不生效,為了度娘才知道,文件my.cnf有兩個,一個在/etc/my.cnf,一個是/usr/local/mysql/my.cnf ## 解決方案二:使用函數ANY\_VALUE()包含報錯字段(不想重啟數據庫,不想改數據庫配置的可以用該方法) 將上述報錯語句改成: ~~~ SELECT ANY_VALUE(ID),USER_ID,ANY_VALUE(problems),ANY_VALUE(last_updated_date) FROM t_iov_help_feedback GROUP BY USER_ID; ~~~ ![](https://img-blog.csdnimg.cn/20210223160822931.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTI2NjA0NjQ=,size_16,color_FFFFFF,t_70) 可以看到,結果能正常查詢了,根據需要自己改查詢字段的別名就行。 ANY\_VALUE()函數說明: ~~~ MySQL有any_value(field)函數,它主要的作用就是抑制ONLY_FULL_GROUP_BY值被拒絕。 這樣sql語句不管是在ONLY_FULL_GROUP_BY模式關閉狀態還是在開啟模式都可以正常執行,不被mysql拒絕。 any_value()會選擇被分到同一組的數據里第一條數據的指定列值作為返回數據。 官方有介紹,地址:https://dev.mysql.com/doc/refman/5.7/en/miscellaneous-functions.html#function_any-value ~~~ 例子: ~~~ Db::name('room')->field('any_value(course_id) as course_id,any_value(room_id) as room_id,count(room_id) as num_total')->where('course_id','>',0)->group('course_id')->select(); ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看