fast-dev
@fast-dev

Mysql как сохранить отрицательное число?

Получаю Numeric value out of range... Out of range value for column
Число -77
Записывается в поле DECIMAL 10,2
Почему и как записывать отрицательные числа?
  • Вопрос задан
  • 43 просмотра
Решения вопроса 1
alexey-m-ukolov
@alexey-m-ukolov Куратор тега MySQL
Колонка, наверное, помечена как unsigned.
Проверил на своей таблице - такая же ошибка, если флаг стоит и нормально вставляется, если флаг снять.
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
@dmitrylee
тыц
DECIMAL[(M[,D])] [UNSIGNED] [ZEROFILL]

A packed “exact” fixed-point number. M is the total number of digits (the precision) and D is the number of digits after the decimal point (the scale). The decimal point and (for negative numbers) the - sign are not counted in M. If D is 0, values have no decimal point or fractional part. The maximum number of digits (M) for DECIMAL is 65. The maximum number of supported decimals (D) is 30. If D is omitted, the default is 0. If M is omitted, the default is 10.

UNSIGNED, if specified, disallows negative values. As of MySQL 8.0.17, the UNSIGNED attribute is deprecated for columns of type DECIMAL (and any synonyms) and will be removed in a future MySQL version. Consider using a simple CHECK constraint instead for such columns.

All basic calculations (+, -, *, /) with DECIMAL columns are done with a precision of 65 digits.
Ответ написан
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы