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 :: знак "&" в mysql

 PHP.SU

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


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

> Без описания
jfr
Отправлено: 13 Января, 2011 - 16:30:01
Post Id



Посетитель


Покинул форум
Сообщений всего: 332
Дата рег-ции: Март 2010  
Откуда: Таджикистан, Худжанд


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

[+]


select 6 & 10 выдает 2, это почему?, объясните пжл...
 
 Top
OrmaJever Модератор
Отправлено: 13 Января, 2011 - 16:43:59
Post Id



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


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


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




потому что 2 числа
(Добавление)
интересно что этим запросом вы хотели взять? Однако

(Отредактировано автором: 13 Января, 2011 - 16:44:32)



-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
jfr
Отправлено: 13 Января, 2011 - 16:47:51
Post Id



Посетитель


Покинул форум
Сообщений всего: 332
Дата рег-ции: Март 2010  
Откуда: Таджикистан, Худжанд


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

[+]


OrmaJever пишет:
потому что 2 числа
(Добавление)
интересно что этим запросом вы хотели взять? Однако


а почему тогда, когда набираю select 10 & 15, то выдает 10? разьве тут 10 чисел?
 
 Top
garvey
Отправлено: 13 Января, 2011 - 16:48:01
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 528
Дата рег-ции: Май 2010  
Откуда: Minsk


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




 
 Top
OrmaJever Модератор
Отправлено: 13 Января, 2011 - 16:50:25
Post Id



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


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


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




Однако в mysql тоже побитовые операторы есть?


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
jfr
Отправлено: 13 Января, 2011 - 17:04:45
Post Id



Посетитель


Покинул форум
Сообщений всего: 332
Дата рег-ции: Март 2010  
Откуда: Таджикистан, Худжанд


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

[+]



можете объяснить там ссылка не открывается...
 
 Top
garvey
Отправлено: 13 Января, 2011 - 17:09:36
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 528
Дата рег-ции: Май 2010  
Откуда: Minsk


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




У меня тоже ссылка долго открывалась. Смысл в следующем. & и AND в MySQL не одно и тоже. AND логическое "И", & - побитовое "И". Не силен в побитовых операциях, но запись 10 & 15 в MySQL делает эту самую побитовую операцию между двумя числами.

MySQL использует для двоичных операций 64-битовые величины BIGINT, следовательно, для двоичных операторов максимальный диапазон составляет 64 бита.
 
 Top
OrmaJever Модератор
Отправлено: 13 Января, 2011 - 17:15:51
Post Id



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


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


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




вот числа от 0 до 10 в 16 битной системе
Спойлер (Отобразить)

Конкретно в даном случае оператор & берёт биты которые есть и в том и в том числе
в 6 и 10 общая только одна единица вторая с конца.
И это равняется числу 2
(Добавление)
http://php.su/learnphp/operators/?bool


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
jfr
Отправлено: 13 Января, 2011 - 17:46:03
Post Id



Посетитель


Покинул форум
Сообщений всего: 332
Дата рег-ции: Март 2010  
Откуда: Таджикистан, Худжанд


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

[+]


OrmaJever пишет:
вот числа от 0 до 10 в 16 битной системе
Спойлер (Отобразить)

Конкретно в даном случае оператор & берёт биты которые есть и в том и в том числе
в 6 и 10 общая только одна единица вторая с конца.
И это равняется числу 2
(Добавление)
http://php.su/learnphp/operators/?bool


спасибо за ответ OrmaJever, теперь все понятно... Улыбка
 
 Top
OrmaJever Модератор
Отправлено: 13 Января, 2011 - 20:34:52
Post Id



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


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


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




А зачем эта функция в mysql? Куда её можно применить?


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
Champion Супермодератор
Отправлено: 13 Января, 2011 - 20:46:01
Post Id



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


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


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




OrmaJever пишет:
Куда её можно применить?
Ну разные задачи бывают. Раз сделали, значит кто-то пользуется. Вот автора темы можно спросить, где он нашел.
 
 Top
JustUserR
Отправлено: 14 Января, 2011 - 14:55:04
Post Id



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


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


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




OrmaJever пишет:
А зачем эта функция в mysql? Куда её можно применить?
Использование побитовых фукнций осуществляется во всех языках программирования являющихся полными относительно предполагаемого набора базовых операций - в частности SQL включает в себя не только формирование целевой выборки информационных полей на основании группы операторов - но и возможнсоть создания полноценных программ типа PL/SQL для которых обеспечение включение битовых операций является обязательным
jfr пишет:
Когда набираю select 10 & 15, то выдает 10
Вычисление указанного выражениия осуществляется в соответствии со следующими правилами
CODE (htmlphp):
скопировать код в буфер обмена
  1.   00001010
  2. * 00001111
  3. -------------
  4.   00001010


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


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB