Покинул форум
Сообщений всего: 126
Дата рег-ции: Март 2010
Помог: 2 раз(а)
snum integer, sname char(10), city char(10), comm float
mysql> select *
-> from salespeople
-> where (comm between .10 and .12) and not comm in (.10, .12);
+------+---------+----------+------+
| snum | sname | city | comm |
+------+---------+----------+------+
| 1001 | Peel | London | 0.12 |
| 1004 | Motika | London | 0.11 |
| 1003 | Azelrod | New York | 0.1 |
+------+---------+----------+------+
3 rows in set (0.00 sec)
почему 1-ю и 3-ю строку выводит? может что то неправильно делаю?
когда пишу where (snum between 1001 and 1003) and not snum in (1001, 1003);
+------+---------+----------+------+
| snum | sname | city | comm |
+------+---------+----------+------+
| 1004 | Motika | London | 0.11 |
+------+---------+----------+------+
----- Нет ничего более постоянного, чем временное.
EuGen
Отправлено: 28 Мая, 2010 - 12:57:44
Профессионал
Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007 Откуда: Berlin
Помог: 707 раз(а)
Для того чтобы всего лишь указать интервал выгоднее использовать '>' и '<'
Используйте так же обычный формат числа (с ведущим нулем: 0.12 например)
----- Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
Petro
Отправлено: 29 Мая, 2010 - 00:50:19
Гость
Покинул форум
Сообщений всего: 126
Дата рег-ции: Март 2010
Помог: 2 раз(а)
да можно было написать
mysql> select *
-> from salespeople
-> where comm > 0.10 and comm < 0.12;
на что получаем вывод тот же
+------+---------+----------+------+
| snum | sname | city | comm |
+------+---------+----------+------+
| 1001 | Peel | London | 0.12 |
| 1003 | Axelrod | New York | 0.1 |
| 1004 | Motika | London | 0.11 |
+------+---------+----------+------+
3 rows in set (0.00 sec)
но для snum все выводит отлично!
mysql> select *
-> from salespeople
-> where snum > 1001 and snum < 1004;
+------+---------+----------+------+
| snum | sname | city | comm |
+------+---------+----------+------+
| 1002 | Serres | San Jose | 0.13 |
| 1003 | Axelrod | New York | 0.1 |
+------+---------+----------+------+
2 rows in set (0.00 sec)
вопрос остается открытым. (почему выводит запись с 0.12 и 0.11 когда в условии указано их не выводить)
мое мнение что это из-за типа данных comm -> float , и как тогда жить?
----- Нет ничего более постоянного, чем временное.
Champion
Отправлено: 29 Мая, 2010 - 09:39:33
Активный участник
Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008 Откуда: Москва
Помог: 57 раз(а)
Petro пишет:
мое мнение что это из-за типа данных comm -> float , и как тогда жить?
Правильное мнение. В компутере это число не 0.12, а 0.12многомногонулей1. Просто отображается оно так. Вещи типа float на равенство сравнивать без округления - как правило, бессмысленное занятие. Любо нужно окуруглить и сравнить, либо сравнивать диапозон: comm between 0.1199999 and 0.1200001
Petro
Отправлено: 29 Мая, 2010 - 11:37:38
Гость
Покинул форум
Сообщений всего: 126
Дата рег-ции: Март 2010
Помог: 2 раз(а)
Да, спасибо, помогло
mysql> select *
-> from salespeople
-> where (comm between .109 and .119);
+------+--------+--------+------+
| snum | sname | city | comm |
+------+--------+--------+------+
| 1004 | Motika | London | 0.11 |
+------+--------+--------+------+
1 row in set (0.00 sec)
Цитата:
Любо нужно окуруглить и сравнить, ...
изменить тип данных на decimal? но тогда при выводе на экран я буду видеть 0.0 (к стати так и попробовал, теперь по новой нужно заполнять поле comm и как оказалось 0 не сравниваются )
а ни как нельзя изменить тип данных comm таким образом, что б и выводило без округления и сравнивало. (Добавление)
кг, а как мне теперь поле comm заполнить соответственно записям? (Добавление)
как заполнить поле уже выучил и заполнил.
Но вопрос по округлению и сравнению стался.
----- Нет ничего более постоянного, чем временное.
JustUserR
Отправлено: 29 Мая, 2010 - 14:02:53
Активный участник
Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009
Помог: 17 раз(а)
Petro Все дело в том что сравнение осуществялется в завитсимости от SQL-типа данных сравниваемых ячеек - и вводимые вами с SQL-условия строковые/численные константы как правило приводтся в типу сравниваемой ячейки
Если ваши дробные числа имеют точно число знаков до и после запятой то можете или хранить их в целочисленном типе данные подразумевая позицию десятичной точки - или же хранить их как строки с точным числом разрядов где всу пустые разряды заполнены нулями и сравнивать их лексографически
----- Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
Все гости форума могут просматривать этот раздел. Только зарегистрированные пользователи могут создавать новые темы в этом разделе. Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.