字串拆分成集合再做比较

【问题】
有个字段叫作者姓名,该字段内内容为 “作者 1,作者 2,作者 3”,现在想把这个字段里面作者一样,但顺序不一样的记录查找出来,该怎么写?

比如就是 “张三,李四,赵五” ,但有的记录里面为“赵五,张三,李四”,也不一定是这种顺序,就是名字完全一致,但排列的先后顺序不一样的字段。

【回答】

拆分字符串用 SQL 不方便,用 SPL 只要一句:



A

1

$select id,name from tb

2

=A1.group(name.split().sort()).select(~.count()>1).conj()

A2 单元格对 name 拆分排序后再分组,选出有重复者合并

假设数据为:

id name

1 张三, 李四, 赵五

2 李四, 赵五, 张三

3 钱六, 张三, 李四

4 赵五, 李四, 张三

5 aaa,bbb, 张三

6 张三, 钱六, 李四

计算结果为:

1 张三, 李四, 赵五

2 李四, 赵五, 张三

4 赵五, 李四, 张三

6 张三, 钱六, 李四