日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

SQL99标准中的查询(MySQL)

發(fā)布時間:2025/3/20 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL99标准中的查询(MySQL) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

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 表;

Select * from employees cross join 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 為連接列。

select d.department_name,l.city from departments d join locations l using(location_id) where location_id = 1800;

五、SQL99中的內(nèi)連接(inner join)


內(nèi)連接通過 INNER JOIN 來建立兩個表的連接。在內(nèi)連接中使用 INNER JOIN 作為 表的連接,用 ON 子句給定連接條件。INNER JOIN 語句在 性能上其他語句沒有 性能優(yōu)勢。


查詢雇員名字為 OldLu 的雇員 ID,薪水與部門名稱。

Select e.employees_id , e.salary , d.department_name from employees e inner join departments d using(department_id) where e.last_name = “Oldlu”;

總結(jié)

以上是生活随笔為你收集整理的SQL99标准中的查询(MySQL)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。