我需要计算数据库中每个组中有多少用户。不幸的是,数据库设计不是很好,用户 uid 是针对组表中的组存储在 LONGTEXT 字段列名称 owncloudusers 中。
owncloudusers 数据示例:
{i:0;s:36:"25C967BD-AF78-4671-88DC-FAD935FF1B26";i:1;s:36:"40D6866B-EA06-4F39-B509-8CE551CC1924";i:2;s:36:" 7724C600-DE23-45C8-8BFD-326B0138E029";i:3;s:36:"D6FF37EC-11F4-471F-94C9-F3A28416CF1F";i:4;s:36:"F70C6D03-B7BA-44E4-B703-9AF3EED9BC 03" ;}
我想我可以在连接上使用带有 LIKE 的查询来比较用户的 uid 并查看 owncloud 用户内部并查看是否有匹配。
我得到的最接近的是:
SELECT T1.owncloudname, count(T2.owncloud_name) AS Users
FROM oc_ldap_group_members T1
LEFT JOIN oc_ldap_user_mapping T2 ON T1.owncloudusers LIKE('%:"'||T2.owncloud_name||'";%')
GROUP BY owncloudname;
T1 表保存分组以及标记到该组的人员
T2 表保存用户数据。列 owncloud_name 是用户 uid 列
我尝试了在 stackoverflow CONCAT on the LIKE join 和 LIKE('%:"'+T2.owncloud_name+'";%') 上找到的一些方法
但没有喜悦。我当前的语句针对所有组返回 0 个用户,但我知道这是不对的。
我知道很多,但关于连接的问题不知道下一步该去哪里。
任何帮助将不胜感激。
我认为你需要一个简单的
SELECT T1.owncloudname, count(*) AS Users
FROM oc_ldap_group_members T1
LEFT JOIN oc_ldap_user_mapping T2 ON T1.owncloudusers LIKE '%T2.owncloud_name%'
GROUP BY owncloudname;
如果你需要连接尝试
SELECT T1.owncloudname, count(T2.owncloud_name) AS Users
FROM oc_ldap_group_members T1
LEFT JOIN oc_ldap_user_mapping T2 ON T1.owncloudusers
LIKE concat( '%',T2.owncloud_name,'%' )
GROUP BY owncloudname;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)