Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 17.10.2011, 23:53
Solo7 Solo7 вне форума
Прохожий
 
Регистрация: 17.10.2011
Сообщения: 5
Репутация: 10
По умолчанию поиск в SQLite используя LIKE

Здравствуйте!
В проекте Delphi использую SQLite, подключился, делаю выборку, перевожу строки из UTF8, все получается, но с поиском не выходит. Поиск ведется по полю, где строки вида: 100230какой-тотоварname.
Запрос такого вида:
Код:
str := Edit1.Text;
    str := StringReplace(str, ' ', '', [rfReplaceAll]);
    str := AnsiLowerCase(str);
sQuery := 'SELECT name, id, type_id FROM t_cat WHERE id in (SELECT cat_id FROM t_names WHERE search LIKE ''%'+str+'%'')';
sltb := sldb.GetTable(sQuery);
При запросе в базу цифрами или на английском код работает нормально, все выводиться, запрос на русском не работает, у меня выводиться вся база.
В интернете нашел много инфо. Советуют кодировать в UTF8 при запросе в базу. Примерно так:
Код:
sldb.GetTable := AnsiString(UTF8Decode(sldb.GetTable('SELECT name, id, type_id FROM t_cat WHERE id in (SELECT cat_id FROM t_names WHERE search LIKE ''%'+str+'%'')');
У меня пишет ошибка несочетаемые типы.
Пробывал кодировать строку перед запросом в базу
Код:
str := UTF8Decode(str);
ничего не выходит(проверял в Tmemo выводится пустая строка).
Понимаю, что для многих это легко и просто, но я недавно в Delphi и с этим не выходит разобраться.
Буду благодарен совету или ссылке, как выполнить запрос на русском.
Ответить с цитированием
  #2  
Старый 18.10.2011, 00:23
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,035
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Мои эксперименты показали, что все, что не на англ, работает неправильно (относительно LIKE). Соответсвенно, просто перешел на EmbeddedFB.
Ответить с цитированием
  #3  
Старый 18.10.2011, 01:00
Solo7 Solo7 вне форума
Прохожий
 
Регистрация: 17.10.2011
Сообщения: 5
Репутация: 10
По умолчанию

lmikle,
я видел проект на delphi с поиком на русском, может конечно, там не LIKE. Но пишут же на форумах, что используя код для перевода строки в UTF8( как костыль) и им этого хватало.
Просто у меня уже мало времени для перехода на другую базу. В SQLite все написано и база и удобно(проект будет на CD).
Помогите с правильным кодом перевода строки в UTF8, возможно, что-то получится
Ответить с цитированием
  #4  
Старый 18.10.2011, 01:05
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,035
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну, тогда, для начала, я бы смотрел на UTF8Encode. Тебе ведь надо ЗАКОДИРОВАТЬ строку в utf. Это раз. Два. А WideString не пробовал?

ЗЫ. Переход на EmbeddedFB не так сложен, как кажется. Хотя, судя по коду, ты напрямую библиотеку используешь. Я пользовался оберткой-наследником TDataSet и переход был очень простой.
Ответить с цитированием
  #5  
Старый 18.10.2011, 06:59
Solo7 Solo7 вне форума
Прохожий
 
Регистрация: 17.10.2011
Сообщения: 5
Репутация: 10
По умолчанию

lmikle,
Использую SQLiteWrapper
Делаю так:
Код:
bdz: WideString;
bdz := UTF8Encode(str);
В базу идет русский текст.
А так
Код:
sltb := AnsiString(UTF8Encode(sldb.GetTable('SELECT name, id, type_id FROM t_cat WHERE id in (SELECT cat_id FROM t_names WHERE search LIKE ''%'+bdz+'%'')')));
Не компилиться, пишет: There is no overloaded version of 'UTF8Encode' that can be called with these arguments.
Ответить с цитированием
  #6  
Старый 18.10.2011, 07:02
Solo7 Solo7 вне форума
Прохожий
 
Регистрация: 17.10.2011
Сообщения: 5
Репутация: 10
По умолчанию

Понимаю, что как-то не так использую UTF8Encode, подскажите где ошибка.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра
Комбинированный вид Комбинированный вид

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 15:07.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter