zoukankan      html  css  js  c++  java
  • 不等值连接

    到目前为止,本书中所有的连接几乎都是等值连接,也就是在这种连接的ON子句的条件包含一个等号运算。等值连接是最常用的连接,因为它指定的连接条件是一个表中的一个字段必须等于另一个表中的一个字段。

    处理等值连接,还存在另外一种不等值连接,也就是在连接的条件中可以使用小于(<)、大于(>)、不等于(<>)等运算符,而且还可以使用LIKE、BETWEEN AND等运算符,甚至还可以使用函数。

    例如,如果需要检索价格小于每个客户的年龄的五倍值的订单列表,那么就可以使用不等值连接,实现的SQL语句如下所示:

    
    SELECT T_Order.FNumber,T_Order.FPrice,T_Customer.FName,T_Customer.FAge FROM T_Order INNER JOIN T_Customer ON T_Order.FPrice< T_Customer.FAge*5
    

    执行完毕我们就能在输出结果中看到下面的执行结果:

    
    FNumber FPrice FName FAge
    
    K001 100.00 TOM 21
    
    K001 100.00 MIKE 24
    
    K001 100.00 JACK 30
    
    K001 100.00 TOM 25
    
    N002 100.00 TOM 21
    
    N002 100.00 MIKE 24
    
    N002 100.00 JACK 30
    
    N002 100.00 TOM 25
    
    T002 100.00 TOM 21
    
    T002 100.00 MIKE 24
    
    T002 100.00 JACK 30
    
    T002 100.00 TOM 25
    

    不等值连接产生了大量的查询结果,因为它是对被连接的两张表做了笛卡尔运算,所以如果只想查看与客户对应的订单,那么就要在不等值连接后添加等值连接匹配条件。实现的SQL语句如下:

    
    SELECT T_Order.FNumber,T_Order.FPrice,T_Customer.FName,T_Customer.FAge FROM T_Order INNER JOIN T_Customer ON T_Order.FPrice< T_Customer.FAge*5 and T_Order.FCustomerId=T_Customer.FId
    

    这里添加了“and T_Order.FCustomerId=T_Customer.FId”这个条件来限制匹配规则。执行完毕我们就能在输出结果中看到下面的执行结果:

    
    FNumber FPrice FName FAge
    
    K001 100.00 TOM 21
    
    N002 100.00 MIKE 24
  • 相关阅读:
    6)图[5]最短路径
    6)图[4]关键路径
    6)图[3]拓扑排序算法
    6)图[2]Prim算法[最小生成树]
    Aprori算法[关联规则算法]
    K-Modes算法[聚类算法]
    linux Centos6.7 python交互模式下回退异常问题解决
    Python-面向对象(二)-Day7
    Python-面向对象(一)-Day7
    (error) MISCONF Redis is configured to save RDB snapshots
  • 原文地址:https://www.cnblogs.com/yuyu666/p/9823707.html
Copyright © 2011-2022 走看看