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 ответов

27 просмотров

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

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
Странно это всё, проверь тип колонки в бд

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

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

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

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
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
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
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта