Задать вопрос
@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 - все ок.
Хотя значения точно присутствуют в таблице, я их вижу, но выбрать запросом не могу.
Подскажите в чем может быть дело? куда рыть? Фильтр на сайте не работает из-за этого)
  • Вопрос задан
  • 3014 просмотров
Подписаться 2 Оценить Комментировать
Помогут разобраться в теме Все курсы
  • Skillfactory
    Профессия Fullstack веб-разработчик на JavaScript и PHP
    20 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 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 и проблема решилась.
Всем спасибо!
Ответ написан
Комментировать
Ваш ответ на вопрос

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

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