免费注册 查看新帖 |

Chinaunix

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

这个sql怎么写? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-26 12:27 |只看该作者 |倒序浏览
一张表,4个字段:f1,f2,f3,f4
f1+f2+f3+f4作为主键

有这么一个查询,已知 f1,f2,f3,查询相等的f4

比如表内存放数据如下:

列名     f1      f2             f3          f4

         a        name      goat      1234  
         a        name      goat      2133  
         a        name      goat      2234  
         a        name      ship       2234
         a        age         13         2342
         a        age         13         3567
         a        age         15         2234      

现在条件是
                f1=a, f2=name 时,f3=goat
                f1=a, f2 =age 时, f3=15

那么从这两个输入条件可以找到一个唯一的 f4 = 2234

怎么写这个查询sql?查到满足前三个条件并且f4相等的f4的值?

论坛徽章:
0
2 [报告]
发表于 2009-05-26 12:46 |只看该作者
select f4  form t
   where  (f1=a and f2=name and f3=goat)
        or   (f1=a and f2=age and f3=15)
group by f4 having count(1)=2;

论坛徽章:
0
3 [报告]
发表于 2009-05-26 13:02 |只看该作者
3ks
方案可行。
如果考虑效率的话,还有没有什么更好的方法?

论坛徽章:
0
4 [报告]
发表于 2009-05-26 13:03 |只看该作者
楼上正解

论坛徽章:
0
5 [报告]
发表于 2009-05-26 17:25 |只看该作者
原帖由 yangdon323 于 2009-5-26 13:02 发表
3ks
方案可行。
如果考虑效率的话,还有没有什么更好的方法?


如果考虑效率的话,不应该用这样的表结构
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP