@rodya

MySql почему не находит существующее значение?

Здравствуйте, столкнулся со странной проблемой.

Имеем базу mysql. В ней некая таблица со столбцом "field_value_value" типа float
Скрин: joxi.ru/exX7U_3JTJCFeSkm-sU

делаю запрос прямо в phpmyadmin:
SELECT  `field_value_value` 
FROM  `field_data_field_value` 
WHERE  `field_value_value` = 0.75
ORDER BY  `field_data_field_value`.`field_value_value` ASC 
LIMIT 0 , 30

все ок, возвращает найденные строки

А вот дальше начинается муть.
Ищу 0.7 - пустой результат, 0.375 - все ок, 0.18 - пустой результат, 0.25 - все ок.
Хотя значения точно присутствуют в таблице, я их вижу, но выбрать запросом не могу.
Подскажите в чем может быть дело? куда рыть? Фильтр на сайте не работает из-за этого)
  • Вопрос задан
  • 2991 просмотр
Решения вопроса 2
Fesor
@Fesor
Full-stack developer (Symfony, Angular)
рыть нужно в понимание того, что такое float и double и как это дело хранится в памяти компа.

stackoverflow.com/questions/2567434/mysql-floating...
dev.mysql.com/doc/refman/5.0/en/problems-with-floa...
Ответ написан
Комментировать
@ryzhak
Попробуй поменять числовые значения в БД на decimal
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
@rodya Автор вопроса
Поменял тип с float на decimal и проблема решилась.
Всем спасибо!
Ответ написан
Комментировать
Ваш ответ на вопрос

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

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