当前位置: 首页 > wzjs >正文

赚钱网站建设网站优化推广方案

赚钱网站建设,网站优化推广方案,微企点做的网站怎么去底下的,建设网站包维护文章目录 结论:MySQL没有string_agg,但有GROUP_CONCATGROUP_CONCAT函数的基本用法示例注意事项 系统变量 group_concat_max_len 如何查看和设置查看当前的group_concat_max_len值设置group_concat_max_len值 相关源码相关链接 结论:MySQL没有…

文章目录

    • 结论:MySQL没有string_agg,但有GROUP_CONCAT
    • GROUP_CONCAT函数的基本用法
      • 示例
      • 注意事项
    • 系统变量 group_concat_max_len 如何查看和设置
      • 查看当前的`group_concat_max_len`值
      • 设置`group_concat_max_len`值
    • 相关源码
    • 相关链接


结论:MySQL没有string_agg,但有GROUP_CONCAT

MySQL中没有直接等同于PostgreSQL的string_agg函数的内置函数,但你可以使用GROUP_CONCAT函数来实现类似的功能。GROUP_CONCAT函数可以将多个行的字符串值连接成一个字符串,类似于string_agg

GROUP_CONCAT函数的基本用法

GROUP_CONCAT函数的基本语法如下:

GROUP_CONCAT([DISTINCT] expr [,expr,...] [ORDER BY expr [ASC | DESC]] [SEPARATOR separator])
  • expr:要连接的表达式。
  • DISTINCT:可选,用于指定在连接字符串之前删除重复值。
  • ORDER BY:可选,用于指定连接字符串中值的顺序。
  • SEPARATOR:可选,用于指定连接字符串中值之间的分隔符,默认为逗号。

示例

假设你有一个名为employees的表,其中包含namedepartment列。你可以使用GROUP_CONCAT函数来获取每个部门的所有员工姓名,如下所示:

SELECT department, GROUP_CONCAT(name ORDER BY name ASC SEPARATOR ', ') AS employees
FROM employees
GROUP BY department;

这个查询将返回每个部门及其所有员工的姓名,员工姓名按字母顺序排列,并以逗号和空格分隔。

注意事项

  • GROUP_CONCAT函数的结果是一个字符串,因此它的长度有限制。默认情况下,这个限制是1024个字符,但你可以通过设置group_concat_max_len系统变量来增加这个限制。
  • GROUP_CONCAT函数在MySQL 5.7及更高版本中可用。如果你使用的是MySQL 5.6或更早版本,你可能需要使用其他方法来实现类似的功能。

系统变量 group_concat_max_len 如何查看和设置

在MySQL中,group_concat_max_len是一个系统变量,用于控制GROUP_CONCAT函数返回的结果字符串的最大长度。你可以使用SHOW VARIABLES语句来查看当前的group_concat_max_len值,并使用SET语句来设置新的值。

查看当前的group_concat_max_len

要查看当前的group_concat_max_len值,可以使用以下SQL语句:

SHOW VARIABLES LIKE 'group_concat_max_len';

这将返回group_concat_max_len的当前值。

设置group_concat_max_len

要设置group_concat_max_len的值,可以使用以下SQL语句:

SET [GLOBAL | SESSION] group_concat_max_len = new_value;
  • GLOBAL:用于设置全局值,这将对所有新的客户端连接生效。
  • SESSION:用于设置会话值,这仅对当前客户端连接生效。
    例如,要将group_concat_max_len设置为1000000,可以使用以下SQL语句:
SET GLOBAL group_concat_max_len = 1000000;

或者,仅对当前会话设置:

SET SESSION group_concat_max_len = 1000000;

请注意,增加group_concat_max_len的值可能会导致内存使用量增加,因此在设置较大的值时需要谨慎。

相关源码

判断结果长度的相关源码:sql/item_sum.cc

Item_func_group_concat::add()

调用 dump_leaf_key(table->record[0] + table->s->null_bytes, 1, this);

即:int dump_leaf_key(void *key_arg, element_count count [[maybe_unused]],void *item_arg)

其中dump_leaf_key函数中的关键判断代码如下(正常返回0,异常返回1):

int dump_leaf_key(void *key_arg, element_count count [[maybe_unused]],void *item_arg) {……/*Stop if the size of group_concat value, in bytes, is longer thanthe maximum size.*/if (result->length() > item->group_concat_max_len) {int well_formed_error;const CHARSET_INFO *cs = item->collation.collation;const char *ptr = result->ptr();size_t add_length;/*It's ok to use item->result.length() as the fourth argumentas this is never used to limit the length of the data.Cut is done with the third argument.*/add_length = cs->cset->well_formed_len(cs, ptr + old_length, ptr + item->group_concat_max_len,result->length(), &well_formed_error);result->length(old_length + add_length);item->warning_for_row = true;push_warning_printf(current_thd, Sql_condition::SL_WARNING, ER_CUT_VALUE_GROUP_CONCAT,ER_THD(current_thd, ER_CUT_VALUE_GROUP_CONCAT), item->row_count);/**To avoid duplicated warnings in Item_func_group_concat::val_str()*/if (table && table->blob_storage)table->blob_storage->set_truncated_value(false);return 1;}return 0;
}

相关链接

官方文档:https://dev.mysql.com/doc/refman/8.0/en/aggregate-functions.html#function_group-concat

http://www.dtcms.com/wzjs/99536.html

相关文章:

  • 哈尔滨设计公司排名杭州百度seo代理
  • 深圳制作手机网站网络推广主要是做什么工作
  • 上海网站制作网站建设友情链接源码
  • 什么网站做的号公司官网模板
  • 户外保险网站建站软件
  • 泉州做网站企业搜狗seo怎么做
  • 做图网站大学生兼职百度推广登录平台app
  • 做网盟的网站必须备案地推拉新app推广接单平台免费
  • 广州门户网站制作seo关键词查询工具
  • 如何在百度提交网站微信营销的功能
  • 绍兴做团购的网站旅游新闻热点
  • 湖南网站优化外包费用媒体资源
  • mirages WordPressseo草根博客
  • facebook做网站软文推广网站
  • 网站的设计网站建设技术外包
  • 网站代码免费的怎么给产品找关键词
  • 西宁网站建设服务公司媒体:北京不再公布各区疫情数据
  • 网站快照出现两个宣传软文是什么意思
  • 天津高端网站建设案例凡科建站怎么样
  • 网页版梦幻西游嗜血狂魔攻略seo关键词库
  • 大连网站建设佳熙科技公司在线生成个人网站app
  • 苏州品牌网站建设专门的网页制作工具有
  • 如何做网站静态页面免费推广平台有哪些
  • 公司自建网站需要多少钱重庆森林电影简介
  • 专业的企业网站建设泾县网站seo优化排名
  • 做网站的工资高吗?百度视频免费高清影视
  • 济宁建设公司网站网站seo推广平台
  • 网站建设衤金手指花总十四上海网站建设开发公司
  • 用什么软件做动漫视频网站949公社招聘信息
  • 济宁网站建设软件开发免费seo刷排名