Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: between

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Petro
Отправлено: 28 Мая, 2010 - 12:26:07
Post Id



Гость


Покинул форум
Сообщений всего: 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 |
+------+---------+----------+------+


-----
Нет ничего более постоянного, чем временное.
 
 Top
EuGen Администратор
Отправлено: 28 Мая, 2010 - 12:57:44
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




Для того чтобы всего лишь указать интервал выгоднее использовать '>' и '<'
Используйте так же обычный формат числа (с ведущим нулем: 0.12 например)


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Petro
Отправлено: 29 Мая, 2010 - 00:50:19
Post Id



Гость


Покинул форум
Сообщений всего: 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 , и как тогда жить? Закатив глазки


-----
Нет ничего более постоянного, чем временное.
 
 Top
Champion Супермодератор
Отправлено: 29 Мая, 2010 - 09:39:33
Post Id



Активный участник


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


Помог: 57 раз(а)




Petro пишет:
мое мнение что это из-за типа данных comm -> float , и как тогда жить?
Правильное мнение. В компутере это число не 0.12, а 0.12многомногонулей1. Просто отображается оно так. Вещи типа float на равенство сравнивать без округления - как правило, бессмысленное занятие. Любо нужно окуруглить и сравнить, либо сравнивать диапозон: comm between 0.1199999 and 0.1200001
 
 Top
Petro
Отправлено: 29 Мая, 2010 - 11:37:38
Post Id



Гость


Покинул форум
Сообщений всего: 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 заполнить соответственно записям?
(Добавление)
как заполнить поле уже выучил и заполнил.
Но вопрос по округлению и сравнению стался.


-----
Нет ничего более постоянного, чем временное.
 
 Top
JustUserR
Отправлено: 29 Мая, 2010 - 14:02:53
Post Id



Активный участник


Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009  


Помог: 17 раз(а)




Petro Все дело в том что сравнение осуществялется в завитсимости от SQL-типа данных сравниваемых ячеек - и вводимые вами с SQL-условия строковые/численные константы как правило приводтся в типу сравниваемой ячейки
Если ваши дробные числа имеют точно число знаков до и после запятой то можете или хранить их в целочисленном типе данные подразумевая позицию десятичной точки - или же хранить их как строки с точным числом разрядов где всу пустые разряды заполнены нулями и сравнивать их лексографически


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB