求教一个SQL的语法的写法

turbochen 2002-10-21 11:14:49
A表:
id name
1 chenxu
2 wanghai
3 xiehua

B表:
id property value
1 sex M
1 age 20
2 sex F
2 age 25
3 sex M
3 age 18

请问我要找出所有sex为M,年龄>=20的人,SQL语法该如何写?
...全文
33 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
turbochen 2002-10-21
  • 打赏
  • 举报
回复
thanks to Haiwer(海阔天空),佻的方法最有效。
各人接分了。
昵称被占用了 2002-10-21
  • 打赏
  • 举报
回复
呵呵,这个设计有意思!

SELECT A.* FROM A,B B1,B B2
WHERE A.ID=B1.ID
AND B1.property='SEX' AND B1.value='M'
AND A,ID=B2.ID
AND B2.property='AGE' AND CAST(B2value AS INT)>=20


qqqdong 2002-10-21
  • 打赏
  • 举报
回复
select * from a表 where id in (select id from b表 where (property = 'sex' and value = 'M')
or (property = 'age' and value >= '20') group by id having count(*) >= 2)
奇遇 2002-10-21
  • 打赏
  • 举报
回复
test as:
select name from A where id in (select id from B where sex='M') and id in (select id from B where age >=20)

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧