Выборка записей по конкретным значениям в Python
Если нужно выбрать запись из
какой-либо группы значений полей, можно применить
команду IN
. К примеру, можно выбрать записи, у которых
поле name
имеет значение 'user1'
, 'user3'
или
'user4'
. Это будет выглядеть так:
WHERE id IN ('user1'
, 'user3'
,
'user4'
).
В принципе, для таких вещей можно пользоваться
и командой OR
,
тогда первый пример будет выглядеть так:
WHERE id=1
OR id=3
OR id=7
OR id=14
OR
id=28
. Вариант с IN
все-таки выглядит
проще и изящнее.
Пример
Выберем юзеров, у которых поле
id
имеет значения 1
,
3
, 5
:
query = "SELECT * FROM users WHERE id IN (1, 3, 5)"
Результат выполненного кода:
{'id': 1, 'name': 'user1', 'age': 23, 'salary': 400}
{'id': 3, 'name': 'user3', 'age': 23, 'salary': 500}
{'id': 5, 'name': 'user5', 'age': 27, 'salary': 500}
Пример
Команду IN
можно комбинировать
с другими командами в запросе. Давайте
перепишем предыдущий пример, указав
еще, что возраст юзеров должен быть
более 23
лет:
query = "SELECT * FROM users WHERE id IN (1, 3, 5) AND age>23"
Результат выполненного кода:
{'id': 5, 'name': 'user5', 'age': 27, 'salary': 500}
Практические задачи
Достаньте юзеров, у которых
зарплата имеет значения
400
и 900
.
Достаньте юзеров, возраст которых
составляет 25
, 27
и 28
лет. При этом
id более 2
.