免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2164 | 回复: 5
打印 上一主题 下一主题

如何处理分组后的值匹配 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-07-02 15:43 |只看该作者 |倒序浏览
有一个数组为b 内容为('篮球','足球',’羽毛球');

有一个表user_hobby,结构如下
id 索引字段
user_id,用户编号
hobby,爱好

表内有如下记录
(1,2,'篮球');
(2,2,'足球');
(3,1,'篮球');
(4,1,'羽毛球');
(5,1,'足球');
(6,1,'乒乓球');
......

现在如何在表hobby中找出包含数组b提供中所有爱好的用户编号?

[ 本帖最后由 ssimyili 于 2007-7-2 17:53 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-07-02 16:33 |只看该作者
select user_id from hobby where hobby in (*(可以直接写需要查询的内容,也可以用select语句))

[ 本帖最后由 mxbao 于 2007-7-2 16:35 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2007-07-02 17:55 |只看该作者
这个语句的要求主要就是,满足数组b是用户爱好数组的子集即可

论坛徽章:
0
4 [报告]
发表于 2007-07-03 09:10 |只看该作者
原帖由 mxbao 于 2007-7-2 16:33 发表
select user_id from hobby where hobby in (*(可以直接写需要查询的内容,也可以用select语句))



where子句应该是b(数组)in (* 某用户的所有hobby)

但是目前也没有发现in 能用于数组比较

论坛徽章:
0
5 [报告]
发表于 2007-07-03 14:18 |只看该作者
正则表达式? instr?
可以从这两个方面考虑一下

论坛徽章:
0
6 [报告]
发表于 2007-07-03 14:24 |只看该作者
嗯,正则表达式的确可以实现,但是现在有些担心效率的问题,如果这个连接后,可以使用fulltext就好了

[ 本帖最后由 ssimyili 于 2007-7-5 10:32 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP