zoukankan      html  css  js  c++  java
  • mysql 环境变量之 group_concat_max_len

    今天使用mysql group_concat()函数,对查询的数据进行字符串连接操作。 不过由于查询的结果较多,连接后的结果很长导致不能完全显示。

    查询手册发现如下说明:

    (先说说group_concat函数)

    • GROUP_CONCAT(expr)

    该函数返回带有来自一个组的连接的非NULL值的字符串结果。其完整的语法如下所示: 

    GROUP_CONCAT([DISTINCT] expr [,expr ...]

                 [ORDER BY {unsigned_integer | col_name | expr}

                     [ASC | DESC] [,col_name ...]]

                 [SEPARATOR str_val])

    mysql> SELECT student_name,

        ->     GROUP_CONCAT(test_score)

        ->     FROM student

        ->     GROUP BY student_name;

    Or:

    mysql> SELECT student_name,

        ->     GROUP_CONCAT(DISTINCT test_score

        ->               ORDER BY test_score DESC SEPARATOR ' ')

        ->     FROM student

        ->     GROUP BY student_name;

    在MySQL中,你可以获取表达式组合的连接值。你可以使用DISTINCT删去重复值。假若你希望多结果值进行排序,则应该使用  ORDER BY子句。若要按相反顺序排列,将 DESC (递减) 关键词添加到你要用ORDER BY 子句进行排序的列名称中。默认顺序为升序;可使用ASC将其明确指定。   SEPARATOR 后面跟随应该被插入结果的值中间的字符串值。默认为逗号 (‘,’)。通过指定SEPARATOR '' ,你可以删除所有分隔符。

    使用group_concat_max_len系统变量,你可以设置允许的最大长度。  程序中进行这项操作的语法如下,其中 val 是一个无符号整数:

    SET [SESSION | GLOBAL] group_concat_max_len = val;

    若已经设置了最大长度, 则结果被截至这个最大长度。

    将环境变量group_concat_max_len 增大。默认是1024.我就设置了session级的环境变量将其变为2048(不够用再加大)。解决该问题

  • 相关阅读:
    【LeetCode】17. Letter Combinations of a Phone Number
    【LeetCode】16. 3Sum Closest
    【LeetCode】15. 3Sum 三个数和为0
    【LeetCode】14. Longest Common Prefix 最长前缀子串
    【LeetCode】13. Roman to Integer 罗马数字转整数
    【LeetCode】12. Integer to Roman 整型数转罗马数
    【LeetCode】11. Container With Most Water
    【LeetCode】10. Regular Expression Matching
    Models of good programmer
    RSA Algorithm
  • 原文地址:https://www.cnblogs.com/xiaoleiel/p/8316623.html
Copyright © 2011-2022 走看看