Задать вопрос
@MuoDosta

Как найти пользователя в БД Sqlite3 Python?

Здравствуйте.

У меня есть код:
import sqlite3

conn = sqlite3.connect(':memory:')
cur = conn.cursor()

    

cur.execute("""CREATE TABLE IF NOT EXISTS users(
   id TEXT,
   name TEXT,
   family TEXT,
   gender TEXT);
""")
conn.commit()

customers = [
  ('00005', 'Stephanie', 'Stewart', 'female'), ('00006', 'Sincere', 'Sherman', 'female'), ('00007', 'Sidney', 'Horn', 'male'), 
  ('00008', 'Litzy', 'Yates', 'female'), ('00009', 'Jaxon', 'Mills', 'male'), ('00010', 'Paul', 'Richard', 'male'), 
  ('00011', 'Kamari', 'Holden', 'female'), ('00012', 'Gaige', 'Summers', 'female'), ('00013', 'Andrea', 'Snow', 'female'), 
  ('00014', 'Angelica', 'Barnes', 'female'), ('00015', 'Leah', 'Pitts', 'female'), ('00016', 'Dillan', 'Olsen', 'male'), 
  ('00017', 'Joe', 'Walsh', 'male'), ('00018', 'Reagan', 'Cooper', 'male'), ('00019', 'Aubree', 'Hogan', 'female'), 
  ('00020', 'Avery', 'Floyd', 'male'), ('00021', 'Elianna', 'Simmons', 'female'), ('00022', 'Rodney', 'Stout', 'male'), 
  ('00023', 'Elaine', 'Mcintosh', 'female'), ('00024', 'Myla', 'Mckenzie', 'female'), ('00025', 'Alijah', 'Horn', 'female'),
  ('00026', 'Rohan', 'Peterson', 'male'), ('00027', 'Irene', 'Walters', 'female'), ('00028', 'Lilia', 'Sellers', 'female'), 
  ('00029', 'Perla', 'Jefferson', 'female'), ('00030', 'Ashley', 'Klein', 'female')
]


cur.executemany("INSERT INTO users VALUES(?, ?, ?, ?);", customers)
conn.commit()

id = '00011'

cur.execute("SELECT * FROM users;")
all = cur.fetchall()
for x in all:
    if x[0] == str(id):
        a = 'Open'
        print(a)
        #if ......
        break
    else:
        a = 'Close'
        # if ......
        print(a)

Мне нужно найти пользователя с определенным id в БД.
Подскажите пожалуйста, как это мне сделать? Есть ли другие способы, которые не проверяют всё БД?
  • Вопрос задан
  • 917 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
@o5a
Почитайте основы SQL (например https://proglib.io/p/sql-for-20-minutes)

Для получения информации там есть своя система фильтров. В данном случае просто
cur.execute("SELECT * FROM users WHERE id = ?", (id, ))
all = cur.fetchone()

в all будет запись с этим пользователем, если есть, или None, если отсутствует.
или так
cur.execute("SELECT COUNT(*) FROM users WHERE id = ?", (id, ))
cnt = cur.fetchone()[0]
в cnt будет кол-во записей с этим пользователем, т.е. 1 если есть, 0 если нет.
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы