数据库是 什么是交叉表查询

数据库是 什么是交叉表查询,第1张

交叉表是一种常用的分类汇总表格。使用交叉表查询,显示源于表中某个字段的汇总值,并将它们分组,其中一组列在数据表的左侧,另一组列在数据表的上部。行和列的交叉处可以对数据进行多种汇总计算,如:求和、平均值、记数、最大值、最小值等。使用交叉表查询数据非常直观明了,被广泛应用。交叉表查询也是数据库的一个特点。

例如:

select 表1.组名,

(select 表1.成员姓名 from 表2 b where 表1.成员1id=表2.成员id) as 成员1id,

(select 表1.成员姓名 from 表2 b where 表1.成员2id=表2.成员id) as 成员2id,

(select 表1.成员姓名 from 表2 b where 表1.成员3id=表2.成员id) as 成员3id

from 表1,表2

--这种就是交叉表查询

左右连接其实就是以哪个表为主(或者说为准),结果集为“主表”的全部记录+“副表”与“主表”相匹配的记录,如果“副表”中没有和“主表”相匹配的记录,则相对应的记录显示为NULL

左连接:左边表全部行+右边表相匹配的行,如果左边表中的某一行,在右边表中没有匹配的行,则显示NULL(left join 或者left outer join)

右连接:和左连接相反。(right join 或者right outer join)

内连接:它返回字段ID(连接条件)同时存在于两个表中的记录,也就是说,仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行,内联接消除与另一个表中的任何行不匹配的行。(inner join或者join)

全连接:不管匹配不匹配,全部都显示出来。(full join或者full outer join)

交叉连接:没有WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(cross join不带where)

自连接:给自己取个别名,一个表当两个表来使用。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9956328.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存