zoukankan      html  css  js  c++  java
  • MariaDB Subquery

    MariaDB Subquery

    prod_id ==> order_num

    (jlive)[crashcourse]>SELECT order_num FROM orderitems WHERE prod_id = 'TNT2';

    +-----------+

    | order_num |

    +-----------+

    |     20005 |

    |     20007 |

    +-----------+

    2 rows in set (0.00 sec)

    order_num ==> cust_id

    (jlive)[crashcourse]>SELECT cust_id FROM orders WHERE order_num IN (20005,20007);

    +---------+

    | cust_id |

    +---------+

    |   10001 |

    |   10004 |

    +---------+

     

    2 rows in set (0.00 sec)

    cust_id ==> cust_name,cust_contact

    (jlive)[crashcourse]>SELECT cust_name, cust_contact FROM customers WHERE cust_id IN (10001,10004);

    +----------------+--------------+

    | cust_name      | cust_contact |

    +----------------+--------------+

    | Coyote Inc.    | Y Lee        |

    | Yosemite Place | Y Sam        |

    +----------------+--------------+

     

    2 rows in set (0.00 sec)



    (jlive)[crashcourse]>SELECT cust_name, cust_contact FROM customers WHERE cust_id IN (SELECT cust_id FROM orders WHERE order_num  IN (SELECT order_num FROM orderitems WHERE prod_id = 'TNT2'));

    +----------------+--------------+

    | cust_name      | cust_contact |

    +----------------+--------------+

    | Coyote Inc.    | Y Lee        |

    | Yosemite Place | Y Sam        |

    +----------------+--------------+

     

    2 rows in set (0.01 sec)

    (jlive)[crashcourse]>SELECT cust_name, cust_contact FROM customers, orders, orderitems WHERE customers.cust_id = orders.cust_id AND orderitems.order_num = orders.order_num AND prod_id = 'TNT2';

    +----------------+--------------+

    | cust_name      | cust_contact |

    +----------------+--------------+

    | Coyote Inc.    | Y Lee        |

    | Yosemite Place | Y Sam        |

    +----------------+--------------+

     

    2 rows in set (0.00 sec)

    (jlive)[crashcourse]>SELECT cust_name, cust_contact FROM customers AS c, orders AS o, orderitems AS oi WHERE c.cust_id = o.cust_id AND oi.order_num = o.order_num AND prod_id = 'TNT2';

    +----------------+--------------+

    | cust_name      | cust_contact |

    +----------------+--------------+

    | Coyote Inc.    | Y Lee        |

    | Yosemite Place | Y Sam        |

    +----------------+--------------+

     

    2 rows in set (0.00 sec)



    子查询混合计算

    (jlive)[crashcourse]>SELECT COUNT(*) AS orders FROM orders WHERE cust_id = 10001;

    +--------+

    | orders |

    +--------+

        2 |

    +--------+

     

    1 row in set (0.00 sec)

    (jlive)[crashcourse]>SELECT cust_id, cust_name, cust_state, (SELECT COUNT(*) FROM orders WHERE orders.cust_id = customers.cust_id) AS orders FROM customers ORDER BY cust_name;

    +---------+----------------+------------+--------+

    | cust_id | cust_name      | cust_state | orders |

    +---------+----------------+------------+--------+

    |   10001 | Coyote Inc.    | MI             2 |

    |   10005 | E Fudd         | IL             1 |

    |   10002 | Mouse House    | OH             0 |

    |   10003 | Wascals        | IN             1 |

    |   10004 | Yosemite Place | AZ             1 |

    +---------+----------------+------------+--------+

     

    5 rows in set (0.00 sec)

  • 相关阅读:
    python基础练习:
    py+selenium切换到新弹出窗口通用方法
    Python 异常处理
    验证码自动化认证部分,可能由于分辨率导致截图不正确
    基于Tesseract的OCR图像识别
    Spark相关知识
    Hive和数据库除了拥有类似的查询语言,再无类似之处;关系型数据库和非关系型数据库的优缺点
    sed替换^A(01),02,03等特殊字符
    Python操作adb命令脚本
    python从放弃到放弃
  • 原文地址:https://www.cnblogs.com/lixuebin/p/10814185.html
Copyright © 2011-2022 走看看