溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例

發(fā)布時(shí)間:2021-01-22 11:55:13 來(lái)源:億速云 閱讀:152 作者:小新 欄目:MySQL數(shù)據(jù)庫(kù)

小編給大家分享一下數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

 問(wèn)題最終要求的結(jié)果是這樣的

數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例

是不是很簡(jiǎn)單?

然而,數(shù)據(jù)庫(kù)是這樣式的

數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例

忽略續(xù)借操作,只關(guān)注借書(shū)、還書(shū)操作。

數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例

就是說(shuō)同一張表,同一本書(shū),既可以存借書(shū),也可以存歸還,而且同一本書(shū)還可能借出或者歸還多次。

其他屬性好說(shuō),比較麻煩的就是這個(gè)歸還時(shí)間,同一本書(shū),緊跟著借書(shū)操作的還書(shū)操作,才是它的歸還時(shí)間。

解決方案是這樣的:

把借出操作記為A表,歸還操作記為B表:其中A表22行,B表19行

數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例

連接條件應(yīng)當(dāng)為藏書(shū)的編號(hào)和讀者的id ,連接的結(jié)果為58行。由于數(shù)據(jù)中,同一本書(shū)名有好幾個(gè)編號(hào),我把書(shū)名給去掉了,連接的結(jié)果是這樣的

數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例

可以看出如果上的記錄框圖框出來(lái)的就是問(wèn)題的所在!框圖框出來(lái)的都是同一條借書(shū)記錄,它跟每一條的還書(shū)記錄連接。從記錄里可以看出,我讓這個(gè)人借了六次同一本書(shū),做了六次的連接!

以下規(guī)則可以幫助我們查詢出正確的結(jié)果

1)同一組借還操作,借操作一定在還操作之前

2)排除掉借操作時(shí)間>還操作的時(shí)間的記錄之后,最早的還書(shū)時(shí)間,就是這個(gè)人,這本書(shū)的還書(shū)時(shí)間

最終結(jié)果是這樣的

最終SQL代碼是這樣的

select A.*,min(B.操作時(shí)間) 還書(shū)時(shí)間 from aleft join 
 bon a.書(shū)籍的典藏編號(hào) = b.書(shū)籍的典藏編號(hào) and a.讀者id = b.讀者id 
and a.操作時(shí)間<b.操作時(shí)間group by a.書(shū)籍的典藏編號(hào),a.操作名稱,a.操作時(shí)間,a.讀者id

數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例

用的是左外連接,未歸還的還書(shū)時(shí)間當(dāng)然就是NULL啦。這樣,其他的子查詢、聯(lián)合、分頁(yè)都不是問(wèn)題了。

以上是“數(shù)據(jù)庫(kù)中聯(lián)合查詢的示例”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI