SQL中笛卡爾積的實際應(yīng)用
1.概念
百度百科:
笛卡爾乘積是指在數(shù)學(xué)中,兩個集合X和Y的笛卡爾積(Cartesian product),又稱直積,表示為X × Y,第一個對象是X的成員而第二個對象是Y的所有可能有序?qū)Φ钠渲幸粋€成員
百度百科有點繞,定義自己解釋自己,意思大概是這個意思,可以簡單理解成兩個集合的乘積
2.sql笛卡爾積語法
select * from table1,table2
其中table1和table2 分別表示兩個表的表名
示例:
2.1 表1有2條數(shù)據(jù)
2.2 表2有3條數(shù)據(jù)
2.3 笛卡爾積有6條數(shù)據(jù)
從行和列兩個維度來觀察上例笛卡爾積的結(jié)果集可以發(fā)現(xiàn),
結(jié)果集的行是表1的行數(shù)乘表2的行數(shù)(2x3)
結(jié)果集的列是表1的列加表2的列(3+4)
3.sql中的應(yīng)用
3.1 高中數(shù)學(xué)集合中有介紹交集、并集、差集、笛卡爾積,一個sql語句可以理解成一個結(jié)果集,多個表的關(guān)聯(lián)查詢底層實際上是數(shù)學(xué)中集合和集合的關(guān)系。
進一步可以發(fā)現(xiàn)笛卡爾積和內(nèi)連接的sql語句可以相互轉(zhuǎn)化,這對我們理解內(nèi)連接的本質(zhì)和笛卡爾積的查詢條件很重要
內(nèi)連接也可以得到2.3笛卡爾積的結(jié)果
3.2 笛卡爾積加查詢條件
轉(zhuǎn)化成內(nèi)連接查詢
總結(jié)
從結(jié)果上來看:內(nèi)連接不加關(guān)聯(lián)條件的結(jié)果就是笛卡爾積
從執(zhí)行效率和底層實現(xiàn)來看,內(nèi)連接和笛卡爾積有區(qū)別,內(nèi)連接會先通過on條件過濾兩張表的數(shù)據(jù),再取交集;笛卡爾積會先將兩個表取乘積再過濾數(shù)據(jù),所以理論上內(nèi)連接效率更高
笛卡爾積在表數(shù)據(jù)量大的情況下查詢結(jié)果會倍增,實際應(yīng)用中要加查詢條件過濾數(shù)據(jù)
怎么理解笛卡爾積中的查詢條件,可以將笛卡爾積sql轉(zhuǎn)化成內(nèi)連接sql去理解
到此這篇關(guān)于SQL中笛卡爾積的文章就介紹到這了,更多相關(guān)SQL中笛卡爾積內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot連接MySQL獲取數(shù)據(jù)寫后端接口的操作方法
今天通過本文給大家介紹SpringBoot連接MySQL獲取數(shù)據(jù)寫后端接口的操作方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-11-11MySQL中使用SHOW PROFILE命令分析性能的用法整理
這篇文章主要介紹了MySQL中使用show profile命令分析性能的用法整理,show profiles是數(shù)據(jù)庫性能優(yōu)化的常用命令,需要的朋友可以參考下2015-11-11MySQL中實現(xiàn)高性能高并發(fā)計數(shù)器方案(例如文章點擊數(shù))
這篇文章主要介紹了MySQL中實現(xiàn)高性能高并發(fā)計數(shù)器方案,本文中的計數(shù)器是指如文章的點擊數(shù)、喜歡數(shù)、瀏覽次數(shù)等,需要的朋友可以參考下2014-10-10mysql 存儲過程判斷重復(fù)的不插入數(shù)據(jù)
這篇文章主要介紹了下面是一個較常見的場景,判斷表中某列是否存在某值,如果存在執(zhí)行某操作,需要的朋友可以參考下2017-01-01CentOS7下 MySQL定時自動備份的實現(xiàn)方法
這篇文章主要介紹了CentOS7 下MySQL定時自動備份的實現(xiàn)方法,主要實現(xiàn)了數(shù)據(jù)庫備份,清理過期備份文件功能,需要的朋友可以參考下2019-12-12