zoukankan      html  css  js  c++  java
  • mysql函数之五:group_concat mysql 把结果集中的一列数据用指定分隔符转换成一行

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

    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;

    但有语法错误,如图所示,暂时无法解决

  • 相关阅读:
    待解决问题
    [OpenCL DEBUG之路]OpenCL开发环境搭建注意点
    基于Matlab的Arnold图像置乱算法
    笔记第1篇-OpenCL基础
    Windows7_64位 NVIDIA 卡 OpenCl环境配置
    4-OpenCL进阶-GPU内存结构和性能优化
    2-OpenCL-深入理解API
    1-OpenCL-"Hello OpenCL"详解
    0-OpenCL基础知识
    3-OpenCL快速入门教程
  • 原文地址:https://www.cnblogs.com/duanxz/p/5098240.html
Copyright © 2011-2022 走看看