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

Народ, я тут чет подзастрял вот с такой фигней на

алхимии. Мне в фастапи прилетают строковые даты в формате ISO-8601 по UTC, то есть с суффиксом Z (это формат такой, сво тут не при чем).

2022-06-28T19:33:26.711Z

Фастапи + пайдентик правильно это распаршевают и декодируют вот в подобное

datetime.datetime(2022, 6, 28, 19, 33, 26, 711000, tzinfo=datetime.timezone.utc)

В модели бд у меня написано вот так:

class Entity(Base):
...
timestamp = Column(DateTime(timezone=True))

И при сохранении данных через алхимию получаю вот такую ошибку:

invalid input for query argument $3: datetime.datetime(2022, 6, 28, 19, 33, 26, 711000, tzinfo=datetime.timezone.utc) (can't subtract offset-naive and offset-aware datetimes)

Пробовал определить поле вот так:

class Entity(Base):
...
timestamp = Column(DateTime)

результат тот же. По тексту ошибки в сети написаны какие-то костыли по конвертации времени со смещением, полученного из бд, но у меня проблема обратная - не записывается в бд. В доке что-то тоже ничего вменяемого не нашел. Куда смотреть?

17 ответов

44 просмотра

Меня смущает вычитание там

Tom-Cauf Автор вопроса
Tishka17
Меня смущает вычитание там

Меня тоже, но я операции вычитания не применяю.

Tom-Cauf Автор вопроса
Tishka17
Покажи больше Трейса

Тебе какого именно куска? Он строк на 400

Tom Cauf
Тебе какого именно куска? Он строк на 400

Ну хотя бы где видно что в качестве $3 летит

Вообще ещё квери, ты делаешь merge?

Tom-Cauf Автор вопроса
Tishka17
Ну хотя бы где видно что в качестве $3 летит

Так сразу после двоеточия значение же datetime и стоит. Это и есть значение третьего аргумента

А какой коннектор?

Tom-Cauf Автор вопроса
Tishka17
Вообще ещё квери, ты делаешь merge?

Эммм. Нет. Это просто SELECT. Аргументы все в WHERE-кондишен определены. Сейчас скину кусок

Tom-Cauf Автор вопроса
Tom-Cauf Автор вопроса
Tishka17
Вообще ещё квери, ты делаешь merge?

SELECT ... WHERE entity.id = %s AND entity.name = %s AND entity.timestamp = %s LIMIT %s OFFSET %s

Tom Cauf
SELECT ... WHERE entity.id = %s AND entity.name = ...

Это кажется не сохранение

Tom-Cauf Автор вопроса
Tishka17
Это кажется не сохранение

Неа, я наебнулся и написал неправильно то место, где возникает ошибка. Это запрос на проверку условий существования. Не суть. Сперва запрашиваем определенное количество записей и проверяем, что среди них нет того, что нужно добавить.

Tom Cauf
Неа, я наебнулся и написал неправильно то место, г...

Странно это всё, проверь тип колонки в бд

Tom-Cauf Автор вопроса
Tishka17
Странно это всё, проверь тип колонки в бд

Ага, я алембиком накатывал бд без таймзоны.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта