Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: Поиск по первым буквам всех слов в названии фирмы

Сообщения:  [1-10]   [11-14] 

 
 автор: Port_Artur1   (10.06.2011 в 10:49)   письмо автору
 
   для: parczynski   (10.06.2011 в 10:22)
 

parczynski, спасибо вам большое, работает просто отлично, единственно мне пришлось заключить переменные в {}, где-то я такой пример про скобки вчера здесь видел, после скобок заработало, а иначе вообще не хотело никак работать (вообще перестало выводить результаты), вроде как PHP там чего не так воспринимает...

or ( firmname RLIKE '[[:<:]]{$lowercase}[^[:punct:]]' ) or (firmname RLIKE '[[:<:]]{$uppercase}[^[:punct:]]' )


Спасибо!

  Ответить  
 
 автор: parczynski   (10.06.2011 в 10:22)   письмо автору
 
   для: Port_Artur1   (10.06.2011 в 09:06)
 

WHERE firmname RLIKE '[[:<:]]М[^[:punct:]]' AND firmname RLIKE '[[:<:]]С[^[:punct:]]'


% работает с оператором like, а Rlike это регулярные выражения, и если вам нужно чтобы поиск был по всем введенным буквам а не по любой, то должно быть AND а не OR

  Ответить  
 
 автор: Port_Artur1   (10.06.2011 в 09:06)   письмо автору
 
   для: Port_Artur1   (10.06.2011 в 08:49)
 

Работает, но ищет даже по инициалам индивидуальных предпринимателей. Например ИП Иванов С.К., - его он находит даже по букве К.
Поэтому я решил исключить знаки препинания, коей и я вляется точка, и чтобы выдумали, - перестало работать, вообще не реагирует, как будто этой записи нет:

or ( firmname RLIKE '[[:<:]]$lowercase^[:punct:]' ) or (firmname RLIKE '[[:<:]]$uppercase^[:punct:]' )


Почему? И как написать условие, чтобы не находил?

  Ответить  
 
 автор: Port_Artur1   (10.06.2011 в 08:49)   письмо автору
 
   для: Port_Artur1   (10.06.2011 в 08:35)
 

parczynski, а вот так работает:

or ( firmname RLIKE '[[:<:]]$lowercase' ) or (firmname RLIKE '[[:<:]]$uppercase' )

СПАСИБО Вам большое!

Я только не понял, чем % помешал в предыдущем случае. Не подскажите?!

  Ответить  
 
 автор: Port_Artur1   (10.06.2011 в 08:35)   письмо автору
 
   для: parczynski   (10.06.2011 в 03:57)
 

parczynski, не работает почему то:

or ( firmname RLIKE '[[:<:]]$lowercase%' ) or (firmname RLIKE '[[:<:]]$uppercase%' )

  Ответить  
 
 автор: parczynski   (10.06.2011 в 03:57)   письмо автору
 
   для: Ильдар   (10.06.2011 в 01:55)
 

SELECT * FROM table WHERE firnename RLIKE '[[:<:]]М' AND firnename RLIKE '[[:<:]]С'


а &nbsp; - это ескейп последовательность в HTML. Она в Mysql не должна работать как пробел

  Ответить  
 
 автор: Ильдар   (10.06.2011 в 01:55)   письмо автору
 
   для: Port_Artur   (10.06.2011 в 00:10)
 

тебе пожалуй нужно разбить название фирмы по словам, а потом уже и искать в каждом слове совпадение по первым буквам. Потому что у тебя в любом случае пока будет искать только по первому слову

  Ответить  
 
 автор: Port_Artur   (10.06.2011 в 00:10)   письмо автору
 
   для: Port_Artur   (10.06.2011 в 00:02)
 

Так тоже не хочет:
or ( firmname LIKE '%&nbsp;$lowercase%' ) or (firmname LIKE '%&nbsp;$uppercase%' )

  Ответить  
 
 автор: Port_Artur   (10.06.2011 в 00:02)   письмо автору
 
   для: Port_Artur   (09.06.2011 в 23:40)
 

попробовал вот так:
 or ( firmname LIKE '&nbsp;$lowercase%' ) or (firmname LIKE '&nbsp;$uppercase%' )


Вообще никакой реакции, а вроде должно было заработать

Разве не так?

  Ответить  
 
 автор: Port_Artur   (09.06.2011 в 23:40)   письмо автору
 
   для: Port_Artur   (09.06.2011 в 22:50)
 

символ '%' означает любой один или более симоволов , - а мне нужно только первым буквам слов в поле firmname

  Ответить  

Сообщения:  [1-10]   [11-14] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования