170 похожих чатов

Есть вот такой код, который, используя sqlachemy, берёт все id

из базы данных и сверяет их с тем id, который был передан в функцию.

def register_new_user(user_id, first_name, last_name):
"""This function checks if user exists in the database and adds him there if he doesn't"""
db_user_ids = session.query(TelegramUserProfile.telegram_id)
if user_id in db_user_ids:
return "Welcome back!"
elif user_id not in db_user_ids:
new_user = TelegramUserProfile(
telegram_id=user_id,
telegram_firstname=first_name,
telegram_lastname=last_name
)
session.add_all([new_user])
session.commit()
return "Registered!"
else:
return "Something went wrong while registering..."

Почему даже несмотря на условие if/else мне при вызове функции выдаёт ошибку, которая, судя по всему, связано как раз с этим условием проверки наличия id в бд.

psycopg2.errors.UniqueViolation: duplicate key value violates unique constraint "telegram_user_profile_pkey"
DETAIL: Key (telegram_id)=(579647634) already exists.

Как это решить?
Ну и в целом, не трольте пожалуйста. Я знаю, что эта моя имплементация проверки наличия пользователя в бд далека от идеала. Как можно сделать лучше?

4 ответов

15 просмотров

Проблема возникает при миграции/импорте данных. PostgreSQL перестает понимать столбцы и хочет создать еще одно значение к уникальному столбцу.

Попробуй в try except обернуть

а db_user_ids что содержит? не список кортежей?

а не проще было сделать session.get(TelegramUserProfile, user_id)?

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

Обсуждают сегодня

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Всем привет! Кто пользуется DevExpress, подскажите пожалуйста, реализован ли в TcxGrid в новых версиях поиск по датам как в Экселе (ну т.е. не просто список чекбоксов со значе...
A Z
4
Карта сайта