PHP lareval中group_concat函数数据长度有1024限制截断的解决

在PHP的leravel里编写sql,使用了group_conca函数,结果数据长度总是只拿到1024个字节,后面的全部截断了。

        $floors = DB::select("
                        select 
                            build,
                            floor_id,
                            floor,
                            GROUP_CONCAT(func_id,'&&',func,'&&',rooms SEPARATOR '^^') as funcs
                        from (
                            select 
                                any_value(b.build) as build,
                                any_value(bf.id) as floor_id,
                                any_value(bf.floor) as floor,
                                any_value(rf.id) as func_id,
                                any_value(rf.func) as func,
                                GROUP_CONCAT(r.id,'||',r.prefix,'||',r.room,'||',rt.type,'||',r.r_price,'||',r.`status`,'||',if(req.equipment is null,'',req.equipment),'||',if(wifi.wifi is null,'',wifi.wifi) order by r.room asc SEPARATOR ',,') as rooms
                            from hotel_company_build_floor_room as r 
                            left join hotel_company_room_func as rf on rf.id = r.room_func_id
                            left join hotel_company_room_type as rt on rt.id = r.room_type_id
                            left join hotel_company_build_floor as bf on r.floor_id=bf.id
                            left join hotel_company_build as b on b.id=bf.build_id
                            LEFT JOIN hotel_company_build_floor_room_eq as req on r.id=req.room_id
                            LEFT JOIN hotel_company_build_floor_room_eq_wifi as wifi on req.equipment=wifi.equipment
                            where r.deleted_at is NULL
                                and rf.deleted_at is NULL
                                and rt.deleted_at is NULL
                                and bf.deleted_at is NULL
                                and b.deleted_at is null ".$whereStr."
                            GROUP BY bf.id,rf.id
                        ) as nr GROUP BY floor_id
                        order by build asc,floor asc
                    ");

问题分析:

这个原因在于,MySQL中的group_concat_max_len默认最大限制是1024长度,所以,只要想办法改变了这个长度,即可解决问题。

参考了网上的说明,解决办法如下:

方法1:

简单粗暴,直接修改mysql配置文件my.cnf,在配置文件中加载如下内容:

group_concat_max_len = 1024000

具体操作:

找到配置文件:find / -name my.cnf

编辑配置文件:vim my.cnf

编辑完成后,重启mysql即可。

 

方法2:

将代码里登录mysql的用户权限设置为root超级用户。

在PHP代码里增加下面的语句:

DB::statement('SET GLOBAL group_concat_max_len = 1024000');

即可完成!

 

这样,数据查询到长度即可超过1024字节。

 

参考:

https://www.cnblogs.com/mr-wuxiansheng/p/7911506.html

http://cn.voidcc.com/question/p-mzveoeon-bhx.html

https://stackoverflow.com/questions/11946012/how-to-add-super-privileges-to-mysql-database

https://stackoverflow.com/questions/36635275/1227-access-denied-you-need-at-least-one-of-the-show-databases-privileges

 

当你在使用MySQLGROUP_CONCAT函数时,可能会遇到默认长度限制导致数据截断的情况。为了自定义分隔符并解决这一问题,首先你需要了解如何通过SEPARATOR参数设置自定义分隔符,然后通过调整group_concat_max_len设置来增加字符串的长度限制。具体操作步骤如下: 参考资源链接:[突破MySQL GROUP_CONCAT长度限制:方法与注意事项](https://wenku.csdn.net/doc/6401ac7acce7214c316ec001?spm=1055.2569.3001.10343) 1. **设置自定义分隔符**: 使用GROUP_CONCAT函数时,可以指定一个自定义分隔符,将多个字段值合并为单个字符串。例如,如果你想将一个表中某个字段的多个值用下划线'_'连接,可以使用如下SQL语句: ```sql SELECT GROUP_CONCAT(column_name SEPARATOR '_') FROM table_name; ``` 2. **解决长度限制问题**: 默认情况下,GROUP_CONCAT的结果字符串长度上限是1024字节。要增加这个长度限制,你可以选择以下两种方法之一: - **永久更改**: 你需要编辑MySQL的配置文件(my.ini或***f),找到[mysqld]部分,并添加或修改`group_concat_max_len`的值,如下所示: ```ini [mysqld] group_concat_max_len=1048576 # 设置为1MB,可根据实际需要调整 ``` 修改后,重启MySQL服务以应用更改。 - **临时更改**: 如果你不希望或者不能重启MySQL服务,可以在会话级别临时调整长度限制: ```sql SET GLOBAL group_concat_max_len = 1048576; -- 影响所有后续会话,需要Super权限 OR SET SESSION group_concat_max_len = 1048576; -- 只影响当前会话 ``` 请注意,永久更改会一直有效直到下一次服务重启,而临时更改只在当前会话中有效。 通过以上方法,你可以自定义分隔符并有效解决长度限制导致的数据截断问题。但是,增加group_concat_max_len值需要根据服务器的内存情况谨慎操作,以免对数据库性能造成负面影响。如果需要深入学习GROUP_CONCAT函数的高级使用方法,包括排序、避免截断问题,推荐阅读资料《突破MySQL GROUP_CONCAT长度限制:方法与注意事项》,该资料提供了详细的指导和最佳实践。 参考资源链接:[突破MySQL GROUP_CONCAT长度限制:方法与注意事项](https://wenku.csdn.net/doc/6401ac7acce7214c316ec001?spm=1055.2569.3001.10343)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值