重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
你是要查前十个查询结果中相同的那些记录,而不求前十个相同记录吧,因为这是有差别的,按照你的语句,应该是求前者,即先求出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来获取交集(交集肯定就是主键相等的了,因为关系模式相同)
select * from table1 t where t.a10 or t.b20
and id not in (select id from table1 m where m.a20 and m.b20)
可以使用左连接left join
select A.学号,A.姓名,B.成绩 from
A left join B on A.学号=B.学号;
mysql这垃圾不支持交集的。如果是数据库那么SQL如下SELECT id FROM a WHERE aid=5 INTERSECTSELECT id FROM a WHERE aid=6
在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);
6 print_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);
6 print_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()基本相同,只不过他在比较中还考虑了数组的键。因此,只有在第一个数组中出现,且在所有其他输入数组中也出现的键/值对才返回到结果数组中。
USE S2
假如 S2 与 S1 2个数据库, 没有交集,那么直接执行:
INSERT INTO DATA
SELECT * FROM S1.DATA;
假如 S2 与 S1 2个数据库, 有交集( 主键是 id ),那么执行:
INSERT INTO DATA
SELECT * FROM S1.DATA AS s1data
WHERE s1data.id NOT IN ( SELECT id FROM DATA)