mysql group_concat()函數(shù) 長(zhǎng)度限制修改辦法

group_concat函數(shù)的功能是將某一字段的值按指定的字符進(jìn)行累加,系統(tǒng)默認(rèn)的分隔符是逗號(hào)

1.先舉一個(gè)簡(jiǎn)單的例子
   select group_concat(f_a) from t_one group by f_b;
   按f_b進(jìn)行分組查詢(xún),將每組中的f_a進(jìn)行累加。

2.修改默認(rèn)的分隔符
   select group_concat(f_a  separator  '_') from t_one group by f_b;
   separator  是一個(gè)關(guān)鍵字,后面跟著要進(jìn)行分隔的字符

3.排序
   select group_concat(f_a order by f_a  separator  '_') from t_one group by f_b;

注意:group_concat 函數(shù)有長(zhǎng)度限制,默認(rèn)長(zhǎng)度是1024,可以使用以下兩個(gè)方法解決:

1.要徹底修改,在MySQL配置文件(my.ini)中加上

group_concat_max_len = -1  # -1為最大值或填入你要的最大長(zhǎng)度
#并重啟mysql
#在客戶(hù)端執(zhí)行語(yǔ)句:
show variables like "group_concat_max_len";  
#如果為自己修改的值或4294967295(設(shè)置為-1時(shí))則修改正確。

2. 可以簡(jiǎn)單一點(diǎn),執(zhí)行語(yǔ)句,可以設(shè)置作用范圍

  SET GLOBAL group_concat_max_len=102400;
  SET SESSION group_concat_max_len=102400;
  #該方法在mysql重啟前一直有作用,但mysql一旦重啟,則會(huì)恢復(fù)默認(rèn)的設(shè)置值。

轉(zhuǎn)自:https://www.pianshen.com/article/73801583369/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容