Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> LIKE наоборот, использовать значение поля как паттерн 
:(
    Опции темы
Lib
  Дата 1.2.2008, 20:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 27.10.2006

Репутация: нет
Всего: нет



У меня такой вопрос - у меня есть строковое поле и строка, в которой, помимо всего прочего, может быть значение этого поля, а может и не быть.
Как указать это в WHERE?

Если бы было наоборот - мне нужно было проверить есть ли такой паттерн в моём поле, тогда проще:

WHERE (record1 LIKE '%pattern_1%')

А то ведь наоборот - поле само является частью строки...
Помогите плиз.
PM MAIL   Вверх
Magnifico
Дата 1.2.2008, 22:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 418
Регистрация: 23.1.2008
Где: Московская област ь

Репутация: 1
Всего: 17



 в SQl Server 2005

Код

declare @table table
(
pole nvarchar(255)
)
insert into @table
select 'мама'
union all
select 'мыла'
union all
select 'раму'

declare @stroka nvarchar(255)
set @stroka = 'Мама мыла раму'

select pole from @table
where  @stroka like '%' +pole +'%'




--------------------
Всё  в  порядке   -   спасибо  зарядке  !
PM MAIL   Вверх
Lib
Дата 4.2.2008, 15:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 27.10.2006

Репутация: нет
Всего: нет



Делаю следующее:

Код

UPDATE emailtable SET Status=2 WHERE ('[email protected], [email protected]' LIKE '%' + Email + '%' );


Не получается, запрос отрабатывает, но изменения не вносятся в таблицу.
Если убрать символы процентов по бокам от поля Email, то при точном совпадении строки-паттерна и значения поля изменения в таюблицу заносятся.
Вот такой затык :(

PM MAIL   Вверх
Magnifico
Дата 4.2.2008, 15:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 418
Регистрация: 23.1.2008
Где: Московская област ь

Репутация: 1
Всего: 17



Вроде должно все работать
Код

declare @table table
(
pole nvarchar(255),
status int
)
insert into @table
select 'мама',1
union all
select 'мыла',2
union all
select 'раму',3
union all
select 'пиво',4



UPDATE @table SET Status=2 WHERE ('Мама мыла раму' LIKE '%' + pole + '%' );

select * from @table



--------------------
Всё  в  порядке   -   спасибо  зарядке  !
PM MAIL   Вверх
TicTak
Дата 6.2.2008, 11:16 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 91
Регистрация: 2.3.2005

Репутация: 1
Всего: 1



Может я конечно не понял всю тонкость задачи, но помоему тут приемлемо правило: от перемены слагаемых сумма не меняется.

Какая разница условию LIKE первым имеет поле или значение? Разве так не будет работать:
WHERE (pattern_1 LIKE '%'||record1||'%")?
PM   Вверх
Deniz
Дата 6.2.2008, 13:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

Репутация: 7
Всего: 44



Цитата(TicTak @  6.2.2008,  14:16 Найти цитируемый пост)
Какая разница условию LIKE первым имеет поле или значение? Разве так не будет работать:
WHERE (pattern_1 LIKE '%'||record1||'%")? 
как говорил мой бывший начальник:
Код

- Какая разница между сексом и кексом? Попробуй - узнаешь.


Цитата(Lib @  4.2.2008,  18:21 Найти цитируемый пост)
Не получается, запрос отрабатывает, но изменения не вносятся в таблицу.
СУБД какая?
Попробуй поставить * вместо %


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
ksili
Дата 22.2.2008, 07:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2069
Регистрация: 3.11.2005
Где: Красноярск

Репутация: нет
Всего: 17



По-моему TicTak прав. Поменяйте местами и все будет работать. По-крайней мере я так делал в хранимых процедурах в FireBird, и всё работает
Код

where ((:p_disps='') or (:p_disps like '%'||trim(ID_CHANEL)||'%'))


Это сообщение отредактировал(а) ksili - 22.2.2008, 07:50


--------------------
Ничто так не развивает аналитическое мышление, как отладка сложной программы без возможности пошагового выполнения (с)
PM MAIL   Вверх
Deniz
Дата 22.2.2008, 11:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

Репутация: 7
Всего: 44



ksiliTicTak прав только в одном 
Цитата(TicTak @  6.2.2008,  14:16 Найти цитируемый пост)
WHERE (pattern_1 LIKE '%'||record1||'%")
работать будет.
А вот в этом 
Цитата(TicTak @  6.2.2008,  14:16 Найти цитируемый пост)
помоему тут приемлемо правило: от перемены слагаемых сумма не меняется.
категорически не согласен.
Код
WHERE (pattern_1 LIKE '%'||record1||'%")
и
WHERE (record1 LIKE '%'||pattern_1||'%")
это 2 разных результата по отбираемым записям и по их кол-ву.


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0739 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.