Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Приблизительный поиск в QSqlTableModel, Фильтр по неполному значению 
V
    Опции темы
loneybibi
Дата 24.6.2011, 19:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель
**


Профиль
Группа: Участник
Сообщений: 257
Регистрация: 28.5.2010
Где: Донецк (Украина)

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



Добрый день! smile 

Есть БД MySql, в ней таблица типа "Имя" "Номер телефона".
Использую QSqlTableModel для получения данных.

Например есть 2 таких записи и много других:
Вася Пупкин | 050 123 456 11
Иван Петров | 050 123 666 77

Как используя функцию setFilter() сделать так что бы когда я в поле поиска вводил 123 то мне показало все записи в номерах которых есть эти цифры (Что то вроде LIKE в MySql)? Или как это сделать по другому?


--------------------
Red Hat Fedora 17
Qt 4.8.1 (x64), GCC 4.4.3,
G++ 4.4.3, QtCreator 2.4.1
PM MAIL ICQ   Вверх
borisbn
Дата 24.6.2011, 20:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 4875
Регистрация: 6.2.2010
Где: Ростов-на-Дону

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



Код
model->setFilter( "PhoneNum LIKE %" + lineEdit->Text() + "%" );

чо так не работает ?

Это сообщение отредактировал(а) borisbn - 24.6.2011, 20:40


--------------------
Женщины отличаются от программистов тем, что у них чары состоят из стрингов
PM MAIL Jabber   Вверх
Greeneyed
Дата 25.6.2011, 10:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Можно еще воспользоваться QSortFilterProxyModel. Подавать на нее QSqlTableModel, а результаты фильтрации уже выводить в таблицу.
PM MAIL   Вверх
loneybibi
Дата 26.6.2011, 11:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель
**


Профиль
Группа: Участник
Сообщений: 257
Регистрация: 28.5.2010
Где: Донецк (Украина)

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



Цитата(borisbn @ 24.6.2011,  19:39)
Код
model->setFilter( "PhoneNum LIKE %" + lineEdit->Text() + "%" );

чо так не работает ?

Я не знал что так можно, потому что нигде в документации не нашел ничего по этому, а методом тыка не очень хотелось подбирать как оно работать будет. 

И этот вариант почему то у меня выдает пустую таблицу.


--------------------
Red Hat Fedora 17
Qt 4.8.1 (x64), GCC 4.4.3,
G++ 4.4.3, QtCreator 2.4.1
PM MAIL ICQ   Вверх
Softaz
Дата 1.7.2011, 00:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


wasm
**


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

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



Цитата(loneybibi @  26.6.2011,  11:58 Найти цитируемый пост)
И этот вариант почему то у меня выдает пустую таблицу.

Думается мне, поле PhoneNum - varchar или подобное.
Тогда так: 
Код

model->setFilter( "PhoneNum LIKE '%" + lineEdit->Text() + "%'" );

т.е. окружить значение поля символами '
А  лучше QSqlQuery сделать параметризованный http://doc.qt.nokia.com/latest/qsqlquery.html




--------------------
Разочарованный в .NET
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С/С++: Кроссплатформенное программирование, QT/Gtk+/wxWidgets"
JackYF
Любитель
  • В заголовке темы в квадратных скобках обозначьте используемую вами библиотеку, например: [QT],[GTK],[wx].
  • Если вопрос актуален только для некоторой версии библиотеки, либо, если вы пользуетесь не самой последней версией, укажите это. Например: [QT4], [GTK2].
  • Все начинающие изучать Qt - не забудьте зайти сюда.
  • Проставьте несколько ключевых слов темы, чтобы её можно было легче найти.
  • В вопросе укажите полную версию версию библиотеки, а также все дополнительные используемые программные пакеты.
  • Не забывайте пользоваться кнопкой "Код".
  • Телепатов на форуме нет! Задавайте чёткий, конкретный и полный вопрос. Указывайте полностью ошибки компилятора и компоновщика.
  • Новое сообщение должно иметь прямое отношение к тематике этого раздела. Флуд, флейм, оффтопик запрещены.
  • Категорически запрещается обсуждение вареза, "кряков", взлома программ и т.д.

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

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | С/С++: Кроссплатформенное программирование, Qt/Gtk+/wxWidgets | Следующая тема »


 




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


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

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