簡體   English   中英

滿足一個條件時選擇其余記錄 SQL

[英]Select the rest of the records when one condition is met SQL

我有一個用戶群和分配給他們的語言。

我的桌子:

用戶

id | name

id | name

users_lang_user

id  | users_id  | lang_id

我想檢索在 lang.id = 1 的關系數據庫中至少有一條記錄的用戶,並獲取他們的其他語言。

SELECT * 
from `users` as users 
JOIN `users_lang_user` as lang 
ON lang.user_id = users.id AND lang.lang_id = '1'

但現在我只有 where lang id = 1。

如果這一個條件為真,我如何獲得其余的用戶記錄

例如,我怎樣才能獲得 lang id = 12 的用戶,但也必須有記錄 where lang id = 1

如果我沒記錯的話,您希望獲得至少有兩種語言的用戶名,其中一種必須是 lang_id 1 ,以及與其關聯的語言名稱,而不是具有 lang_id 1 的語言名稱。在工作台中編寫並測試了這個:

 create table users (id int,name varchar(10));
 insert users values(1,'john'),(2,'mary'),(3,'sarah');
 create table lang (id int,name varchar(10));
 insert lang values(1,'english'),(2,'german'),(3,'maori');
 create table users_lang_user(id int,users_id int,lang_id int);
 insert users_lang_user values(1,1,3),(2,3,1),(3,2,1),(4,2,2);
select u.name,l.name from users u 
join users_lang_user ul
    on u.id=ul.users_id
join lang l
    on ul.lang_id=l.id
where ul.users_id in (select users_id from users_lang_user
                    group by users_id having count(users_id)>1 and min(lang_id)=1)
      and lang_id!=1
;
-- result set:
mary german

注意在這種情況下,由於 lang_id 1 恰好是所有值中的最小值,我們可以使用聚合函數min(lang_id)=1來覆蓋未在 group by 子句中列出的 lang_id 列。

一種方法是

SELECT u.*, l.id langId
FROM `users` u 
JOIN (
   SELECT user_id 
   FROM `users_lang_user` 
   WHERE lang_id = '1') ul1 ON u.id = ul1.user_id
JOIN `users_lang_user` l ON l.user_id = u.id

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM