yuehoiwai 2020-09-24 10:47 采纳率: 0%
浏览 108
已采纳

請教列出所有年齡大於21嵗的中國籍男子之person_id之sql語句。

表Person_Attribute結構如下:

field 1: person_id
field 2: attribute_name (gender,nationality,age etc.)
fiield 3: attribute_type (int,double,string etc.)
field 3 : attribute_value (gender(male,female),nationality (chinese,american etc.)

attribute_value 的數據格式為 String

請教列出所有年齡大於21嵗的中國籍男子之person_id之sql語句。

  • 写回答

3条回答 默认 最新

  • jingluan666 2020-09-24 11:16
    关注

    你这个问题只不过是在https://ask.csdn.net/questions/1097516
    的基础上多加了一个条件

    所以只需要多加一个exists

    SELECT p.* FROM person p
    WHERE EXISTS
    (
       SELECT 1 FROM person_attribute pa 
       WHERE p.id=pa.person_id  AND pa.attribute_name='gender' AND pa.attribute_value='male'
    )
    AND EXISTS
    (
       SELECT 1 FROM person_attribute pa 
       WHERE p.id=pa.person_id  AND pa.attribute_name='nationality' AND pa.attribute_value='chinese'
    )
    AND EXISTS
    (
       SELECT 1 FROM person_attribute pa 
       WHERE p.id=pa.person_id  AND pa.attribute_name='age' AND CONVERT(pa.attribute_value,SIGNED)>21
    )
    ORDER BY p.name
    

    以后碰到类似的,要学会举一反三

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?