Eiffel: ODBC работает с BIGINT - PullRequest
       12

Eiffel: ODBC работает с BIGINT

0 голосов
/ 31 января 2019

Eiffel

Кажется, я получаю INTEGER_32_REF от BIGINT из ODBC с Eiffel DB_SELECTION.cursor.Иногда мне кажется, что у меня есть адекватное значение, но иногда нет ...

946383958 => good INTEGER_32_REF (id->4 of following table)
9475984837 => 886050245 WRONG INTEGER_32_REF (id->4 of following table)

646383958 => good INTEGER_32_REF (id->3 of following table)
6475984837 => -2113949755 WRONG INTEGER_32_REF (id->4 of following table)

...

Это похоже на то, что не обрабатывать BIGINT и давать значение INTEGER_32_REF, напрямую интерпретируемое из значения DB, типичный случай, передающийся через2 ^ 32

Postgresql

Имеет таблицу со следующими данными как electricity_amount BIGINT NOT NULL DEFAULT 0

id |   a_date   |  amount   | electricity_amount | consumption_sector_id | electricity_rate_id
----+------------+-----------+--------------------+-----------------------+---------------------
1 | 2019-01-01 | 746383958 |         7475984837 |                     1 |                   1
2 | 2019-02-01 | 846383958 |         8475984837 |                     1 |                   1
3 | 2019-03-01 | 646383958 |         6475984837 |                     1 |                   1
4 | 2019-04-01 | 946383958 |         9475984837 |                     1 |                   1

enter image description here

1 Ответ

0 голосов
/ 02 февраля 2019

По умолчанию не все типы данных отображаются на стороне Eiffel.Так что вам нужно будет наследовать от класса GLOBAL_SETTINGS и вызывать функцию set_use_extended_types (True) --| Use extended types: INTEGER_64, STRING_32 etc.

...