示例:
在MySQL创建两张表:a_table、b_table
随便插入几条数据:
组合两个表中的记录,返回关联字段相符的记录,也就是两个表的交集
left join 是left outer join的简写,它的全称是左外连接,是外连接中的一种。
左表全部记录都会显示出来,右表只显示出满足条件的记录,不足的列全部显示NULL
right join 是 right outer join的简写,它的全程是右外连接,是外链接的一种。
右表全部记录都会显示出来,左表只显示满足条件的记录,不足的列全部显示NULL
有了内联、外联查询,有没有取并集查询呢?当然也有了:
注意:查询报错了!!!
左外查询 union 右外查询
UNION定义:UNION *** 作符用于合并两个或多个 SELECT 语句的结果集。
注意:
UNION 和 UNION ALL 区别:UNION ALL会列出所有结果,有重复,UNION没有重复
inner join: 如果查询的表中都有至少一个匹配,则返回行
left join: 即使右表中没有匹配,也从左表返回所有的行
right join: 即使左表中没有匹配,也从右表返回所有的行
full join: 只要其中一个表中存在匹配,就返回行,但是在mysql中不支持
union:合并多个查询语句的结果集(去重)
union all:合并多个查询语句的结果集(不去重)
更多文章: RelaxHeart网更多博文
你是要查前十个查询结果中相同的那些记录,而不求前十个相同记录吧,因为这是有差别的,按照你的语句,应该是求前者,即先求出A的前十条数据,B的前十条数据,再求它们的交集。既然是求交集,那么这两个表的关系模式应该是相同的了,
select
a.*
from
(select
*
from
table
order
by
table.a
desc
limit
10)
as
a,
(select
*
from
table
order
by
table.b
desc
limit
10)
as
b
where
a.primary_key
=
b.primary_key
--先将两个结果作为两张临时表,然后通过主键
primary_key来获取交集(交集肯定就是主键相等的了,因为关系模式相同)
在PHP中求数组的交集,我们可以与PHP给我们提供的现成函数:array_intersect(),其用法格式为:array array_intersect(array array1,array array2[,arrayN…])
根据上述的语法格式,我们来写一个例子:
1<?php
2$fruit1 = array("Apple","Banana","Orange")
3$fruit2 = array("Pear","Apple","Grape")
4$fruit3 = array("Watermelon","Orange","Apple")
5$intersection = array_intersect($fruit1, $fruit2, $fruit3)
6print_r($intersection)
7// 输出结果:
8// Array ( [0] =>Apple )
9?>
本例子将返回在$fruit1数组中出现且在$fruit2和$fruit3中也出现的所有水果的名子。
使用array_intersect()函数时要注意:只有在两个元素相等且具有相同的数据类型时,array_intersect()函数才会认
为它们是相同的,否则不能进行交集计算。array_intersect()函数返回一个保留了键的数组,只由第一个数组中出现的且在其它数组中都出现的
值组成。
若要求关联数组的交集,请使用array_intersect_assoc()函数,给你个简单的例子:
1<?php
2$fruit1 = array("red"=>"Apple","yellow"=>"Banana","orange"=>"Orange")
3$fruit2 = array("yellow"=>"Pear","red"=>"Apple","purple"=>"Grape")
4$fruit3 = array("green"=>"Watermelon","orange"=>"Orange","red"=>"Apple")
5$intersection = array_intersect_assoc($fruit1, $fruit2, $fruit3)
6print_r($intersection)
7// 输出:
8// Array ( [red] =>Apple )
9?>
array_intersect_assoc()函数语法格式如下:
array array_intersect_assoc(array array1,array array2[,arrayN…])
array_intersect_assoc()与array_intersect()基本相同,只不过他在比较中还考虑了数组的键。因此,只有在第一个数组中出现,且在所有其他输入数组中也出现的键/值对才返回到结果数组中。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)