服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - SQL中笛卡尔积的实际应用

SQL中笛卡尔积的实际应用

2023-03-02 16:13deelless Mysql

笛卡尔积算法,又称为笛卡尔积枚举法,是一种枚举算法,用于在两个或多个集合之间枚举所有可能的组合,这篇文章主要给大家介绍了关于SQL中笛卡尔积的相关资料,需要的朋友可以参考下

1.概念

百度百科:

笛卡尔乘积是指在数学中,两个集合X和Y的笛卡尔积(Cartesian product),又称直积,表示为X × Y,第一个对象是X的成员而第二个对象是Y的所有可能有序对的其中一个成员

百度百科有点绕,定义自己解释自己,意思大概是这个意思,可以简单理解成两个集合的乘积

 

2.sql笛卡尔积语法

select * from table1,table2

其中table1和table2 分别表示两个表的表名

示例:

 

2.1 表1有2条数据

SQL中笛卡尔积的实际应用

 

2.2 表2有3条数据

SQL中笛卡尔积的实际应用

 

2.3 笛卡尔积有6条数据

SQL中笛卡尔积的实际应用

从行和列两个维度来观察上例笛卡尔积的结果集可以发现,
结果集的行是表1的行数乘表2的行数(2x3)
结果集的列是表1的列加表2的列(3+4)

 

3.sql中的应用

3.1 高中数学集合中有介绍交集、并集、差集、笛卡尔积,一个sql语句可以理解成一个结果集,多个表的关联查询底层实际上是数学中集合和集合的关系。

进一步可以发现笛卡尔积和内连接的sql语句可以相互转化,这对我们理解内连接的本质和笛卡尔积的查询条件很重要

内连接也可以得到2.3笛卡尔积的结果

SQL中笛卡尔积的实际应用

3.2 笛卡尔积加查询条件

SQL中笛卡尔积的实际应用

转化成内连接查询

SQL中笛卡尔积的实际应用

 

总结

从结果上来看:内连接不加关联条件的结果就是笛卡尔积
从执行效率和底层实现来看,内连接和笛卡尔积有区别,内连接会先通过on条件过滤两张表的数据,再取交集;笛卡尔积会先将两个表取乘积再过滤数据,所以理论上内连接效率更高
笛卡尔积在表数据量大的情况下查询结果会倍增,实际应用中要加查询条件过滤数据
怎么理解笛卡尔积中的查询条件,可以将笛卡尔积sql转化成内连接sql去理解

到此这篇关于SQL中笛卡尔积的文章就介绍到这了,更多相关SQL中笛卡尔积内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文地址:https://blog.csdn.net/weixin_43078114/article/details/128131481

延伸 · 阅读

精彩推荐
  • MysqlMySQL启用慢查询日志记录方法

    MySQL启用慢查询日志记录方法

    由于程序员写的东西不一定是最优的所以我们只要启用mysql慢查询日志功能就可以分析每一条sql语句所运行相关性能了,下面大家一起来看看 ...

    mysql教程网3142020-07-09
  • MysqlSQL查询语句优化的实用方法总结

    SQL查询语句优化的实用方法总结

    下面小编就为大家带来一篇SQL查询语句优化的实用方法总结。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 ...

    数据库之家3322020-07-05
  • Mysql一文搞懂MySQL预编译

    一文搞懂MySQL预编译

    这篇文章主要介绍了MySQL预编译的相关资料,文中讲解非常详细,示例代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下 ...

    gdwkong9622020-07-08
  • MysqlMySQL 四种事务隔离级别详解及对比

    MySQL 四种事务隔离级别详解及对比

    这篇文章主要介绍了MySQL 四种事务隔离级别详解及对比的相关资料,这里对Mysql 的基础知识做了详细介绍及对其事务隔离进行了比较,需要的朋友可以参考下...

    mysql教程网3502020-07-05
  • Mysql关于MYSQL 你需要知道的数据类型和操作数据表

    关于MYSQL 你需要知道的数据类型和操作数据表

    这篇文章主要介绍了关于MYSQL中数据类型的知识和操作数据表的方法,文中讲解非常详细供大家参考学习,感兴趣的朋友可以了解下...

    米脂5062021-01-20
  • Mysqlmysql如何实现最大连接数

    mysql如何实现最大连接数

    云服务器同时最大连接数,也就是说可以有一千个用户,那么mysql如何实现最大连接数,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣...

    Teingi6952022-02-12
  • MysqlMySQL中用户授权以及删除授权的方法

    MySQL中用户授权以及删除授权的方法

    这篇文章主要介绍了MySQL中用户授权以及删除授权的方法的相关资料,需要的朋友可以参考下 ...

    MYSQL教程网3672020-05-29
  • Mysql解析MySQL binlog

    解析MySQL binlog

    我们都知道,binlog可以说是MySQL中比较重要的日志了,在日常学习及运维过程中,也经常会遇到。不清楚你对binlog了解多少呢?本篇文章将从binlog作用、b...

    kun_行者4082021-08-17