@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 - все ок.
Хотя значения точно присутствуют в таблице, я их вижу, но выбрать запросом не могу.
Подскажите в чем может быть дело? куда рыть? Фильтр на сайте не работает из-за этого)
  • Вопрос задан
  • 2978 просмотров
Решения вопроса 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 и проблема решилась.
Всем спасибо!
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы
30 апр. 2024, в 23:39
3000 руб./за проект
30 апр. 2024, в 23:32
1500 руб./за проект
30 апр. 2024, в 22:44
500 руб./в час