left-join - 關于 mysql 關聯查詢的一些疑惑
問題描述
【join查詢這種黑科技在數據量小的情況下可以使用,基本沒有什么影響,數據量大的時候,join的性能可能會是硬傷,應該盡量避免,可以分別根據索引取單表數據然后在應用層對數據進行join、merge】, 想問下例如現在有三個表 user、department、article, album(專輯)
user表:
id int primary key auto_increment,name char(32),password char(32),created_at bigint,updated_at bigint,is_delete int default 0,dep_id int (對應department表的 `id`)
department表:
id int primary key auto_increment,name char(32),pid int default 0,created_at bigint,updated_at bigint,is_delete int default 0
article表
id int primary key auto_increment,title char(100),content text,user_id int,(對應 user 表的 `id`)cate_id int,album_id int, (對應 album 表的 `id`)created_at bigint,updated_at bigint,is_delete int default 0
album專輯表:
id int primary key auto_increment,title char(100),user_id int, (對應 user 表的 `id`)pid int default 0,created_at bigint,updated_at bigint,is_delete int default 0
現在想查詢 用戶id 為 5 , 并找出屬于他自己 專輯id 為 10 下最新發表的 10 篇文章(這10篇當中當然不能包括被刪除的文章), 不能使用 join 關聯查詢, 而是使用這種方式實現[分別根據索引取單表數據然后在應用層對數據進行join、merge], 該如何實現呢?(最好能夠有sql舉例說明)
問題解答
回答1:首先你要理解什么叫做在應用層面實現。另外一個,你都知道user_id為5了,根本涉及不到什么關聯查詢,你直接:
select * from article where user_id = 5 and is_delete = 0 order by id desc limit 10;
就可以搞定了啊
相關文章:
1. linux - openSUSE 上,如何使用 QQ?2. android - 安卓使用webview播放騰訊、優酷視頻的方法3. python - 有什么好的可以收集貨幣基金的資源?4. npm install -g browser-sync這個之后出錯 還有人嗎 我都感覺沒人回答問題了5. python3.5 urllib.parse.unquote 亂碼6. 關于python的繼承的一個疑問7. javascript - IOS沒有上APP Store如何實現熱更新?8. python - 如何優雅的升級線上Django代碼?9. python - pandas按照列A和列B分組,將列C求平均數,怎樣才能生成一個列A,B,C的dataframe10. MySQL數據庫中文亂碼的原因
