SQL99标准中的查询(MySQL)
SQL99標(biāo)準(zhǔn)中的查詢
MySQL5.7支持SQL99標(biāo)準(zhǔn);
一、笛卡爾乘積
笛卡爾乘積是指在數(shù)學(xué)中,兩個集合 X 和 Y 的笛卡尓積(Cartesian product),又 稱直積,表示為 X * Y,第一個對象是 X 的成員而第二個對象是 Y 的所有可能有 序?qū)Φ钠渲幸粋€成員。
二、SQL99中的交叉連接
?CROSS JOIN 子句導(dǎo)致兩個表的交叉乘積
?該連接和兩個表之間的笛卡爾乘積是一樣的
例
使用交叉連接查詢 employees 表與 departments 表;
三、SQL99中的自然連接
?相當(dāng)于等式連接的另一種寫法,簡化了等值連接的寫法,性能相同;也不是很建議使用;
?NATURAL JOIN 子句基于兩個表之間有相同名字的所有列。
?它從兩個表中選擇在所有的匹配列中有相等值的行。
?如果有相同名字的列的數(shù)據(jù)類型不同,返回一個錯誤。
?當(dāng)有多個列匹配時,用 USING 子句匹配唯一的列。
?自然連接注意事項(xiàng)
1.如果做自然連接的兩個表的有多個字段都滿足有相同名稱和類型,那么他們會被作為自然連接的條件。
2.如果自然連接的兩個表僅是字段名稱相同,但數(shù)據(jù)類型不同,那么將會返回一個錯誤。
3.由于可以進(jìn)行這種非常簡單的 natural join,我們在設(shè)計表時對具有相同含義的字段需要考慮到使用相同的名字和數(shù)據(jù)類型。
例
一、修改 employees 表中的 dept_id 列將該列的名稱修改為 department_id;
Alter table employees change column dept_id department_id int;二、使用自然連接查詢所有有部門的雇員的名字以及部門名稱。
Select e.last_name , d.department_name from employees e natural join departments d;四、Using子句
?如果某列在 USING 中使用,那么在引用該列時不要使用表名或者別名。
?NATURAL JOIN 和 USING 子句是相互排斥的。
例
查詢 location_id 為 1800 的部門名稱以及他們所在的城市名稱,指定location_id 為連接列。
五、SQL99中的內(nèi)連接(inner join)
內(nèi)連接通過 INNER JOIN 來建立兩個表的連接。在內(nèi)連接中使用 INNER JOIN 作為 表的連接,用 ON 子句給定連接條件。INNER JOIN 語句在 性能上其他語句沒有 性能優(yōu)勢。
例
查詢雇員名字為 OldLu 的雇員 ID,薪水與部門名稱。
總結(jié)
以上是生活随笔為你收集整理的SQL99标准中的查询(MySQL)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL中的外连接
- 下一篇: MySQL中的组函数(聚合函数)