group_concat mysql 把结果集中的一列数据用指定分隔符转换成一行
2016-01-04 11:24
741 查看
函数使用说明:该函数返回带有来自一个组的连接的非NULL 值的字符串结果。其完整的语法如下
例子:
结果:
# uin
'1'
'2'
'3'
'44'
'176'
'196'
'204'
'210'
'215'
'237'
'238'
结果:
示例3:
找到管理员及下级管理员所创建的角色:
或者:
但查不出结果来,为什么呢?
因为 group_concat(uin) 得到的结果被当作一个元素,而不是用逗号分隔的一系列value,如何才能得到我想要的效果呢
网络上有说用find_in_set()方法的,如下所示:
但有语法错误,如图所示,暂时无法解决
GROUP_CONCAT([DISTINCT] expr [,expr ...] [ORDER BY {unsigned_integer | col_name | expr } [ASC | DESC] [,col_name ...]] [SEPARATOR str_val ])
例子:
SELECT uin FROM sys_user where uin<240;
结果:
# uin
'1'
'2'
'3'
'44'
'176'
'196'
'204'
'210'
'215'
'237'
'238'
SELECT group_concat(uin,'') FROM sys_user where uin<240;
结果:
示例3:
SELECT uin FROM sys_user where uin=2 or create_user_uin_tree like '%_2_%';
找到管理员及下级管理员所创建的角色:
SELECT * FROM sys_role where ( role_type=1 AND ain in(select uin FROM sys_user where create_user_uin_tree like '%_2_%') ) OR role_id=1;
或者:
SELECT * FROM sys_role where ( role_type=1 AND ain in(select group_concat(uin) FROM sys_user where create_user_uin_tree like '%_2_%') ) OR role_id=1;
但查不出结果来,为什么呢?
因为 group_concat(uin) 得到的结果被当作一个元素,而不是用逗号分隔的一系列value,如何才能得到我想要的效果呢
网络上有说用find_in_set()方法的,如下所示:
SELECT * FROM sys_role where ( role_type=1 AND find_in_set(ain,select group_concat(uin) FROM sys_user where create_user_uin_tree like '%_2_%') ) OR role_id=1;
但有语法错误,如图所示,暂时无法解决
相关文章推荐
- MySql中添加用户,新建数据库,用户授权,删除用户,修改密码
- Mysql table ful
- MySQL Index详解
- Mysql 命令大全
- MySql错误1045 Access denied for user 'root'@'localhost' (using password:YES) windows下的解决方案(忘记密码)
- mysql 取每组前几条记录
- mysql数据导入、导出方法汇总
- 安装mysql
- mysql导入数据load data infile用法
- 如何修改mysql数据库编码
- mysql导出数据不输出标题行
- mysql导出数据中文乱码问题
- mysqldump导出时出现when doing LOCK TABLES
- mysql连接拒绝问题
- mysql操作命令记录
- MySql Host is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts' 解决方法
- mysql 多表联合更新
- MYSQL general tablespace
- mysql profile及其对应表使用
- MySQL5.6分区数量太多引发的血案