|
2 / 2 / 0
Регистрация: 06.06.2018
Сообщений: 49
|
||||||
Поиск по одному или нескольким полям12.11.2019, 21:33. Показов 4657. Ответов 9
Метки нет (Все метки)
Привет. Нужно сделать поиск по одному или нескольким полям
В базе есть Фамилия, Имя, Телефон. И соответственно три поля для ввода Ф, И, Т Сейчас программа находит только если заполнены все поля, а нужно чтобы находила даже по одному из полю. Например, есть у меня Дима Егоров 89992129345 Ищу по фамилии, выдает Дима Егоров 89992129345 Ищу по телефону, выдает Дима Егоров 89992129345 Сейчас код выглядит так и работает, только если заполнены все три поля
0
|
||||||
| 12.11.2019, 21:33 | |
|
Ответы с готовыми решениями:
9
Фильтрация по одному или нескольким полям Поиск по одному или по нескольким столбцам Массив структур: добавление записи, удаление записи, поиск по одному или нескольким из полей |
|
14145 / 9374 / 1350
Регистрация: 21.01.2016
Сообщений: 35,306
|
|||||||
| 13.11.2019, 06:29 | |||||||
|
Правильный запрос должен выглядеть так:
И используйте параметризированные запросы, а не конкатенацию. Примеров что в сети, что на этом форуме навалом. Не скатывайтесь до PHP уровня начала двухтысячных.
0
|
|||||||
|
2 / 2 / 0
Регистрация: 06.06.2018
Сообщений: 49
|
|||||||||||
| 13.11.2019, 23:03 [ТС] | |||||||||||
|
Спасибо!
Но условие ИЛИ не подходит же. В результате такого запроса будет выборка некорректная.
В таком случае выборка идет и по имени и по фамилии. Нужно сделать обязательно с помощью AND, но чтобы при пустом поле, он не учитывал его Добавлено через 3 минуты Сейчас реализовал таким способом. Работает отлично, но вероятнее всего быдлокодски Составляю переменную из $"name LIKE {id1} AND + $" surname LIKE {id2} AND + $" telephone LIKE {id3} AND" и удаляю всегда по проверке последний AND Соответственно если у меня введены только два поля из трех ( имя и телефон ) запросы выглядит так: $"name LIKE {id1} AND + $" telephone LIKE {id3} AND" -(минус) AND
0
|
|||||||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
|||||||
| 13.11.2019, 23:29 | |||||||
|
Ворошитель, вам же сказали использовать параметризованные запросы и показали как должен выглядеть запрос.
Эм, пардон, COALESCE вместо ISNULL, ISNULL в MySql по-другому работает.
0
|
|||||||
|
2 / 2 / 0
Регистрация: 06.06.2018
Сообщений: 49
|
||||||
| 14.11.2019, 01:15 [ТС] | ||||||
|
Спасибо большое! Сейчас читаю про параметризованные запросы, думаю разберусь.
Я наверное неправильно проблему описал. Под пустым полем, я понимаю поле ввода, а не поле таблицы SQL. Есть три поля ввода text.Box1/2/3. Соответственно AND работает только когда все три поля ввода получили в себя данные, а нужно чтобы работал и по одному и по двум, чтобы можно было искать либо по фамилии и имени, либо по имени и телефону, либо только по имени, только по фамилии и так далее. OR не подходит, так как он в кучу мешает и не исключает лишнее
0
|
||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
|||||||
| 14.11.2019, 02:04 | |||||||
|
А вам как показано было сделать?
Или вот так?
0
|
|||||||
|
2 / 2 / 0
Регистрация: 06.06.2018
Сообщений: 49
|
|
| 14.11.2019, 02:23 [ТС] | |
|
Ну в смысле разницы нет, я пробовал и так и так. Результат не меняется.
Как я понял это все проверка на пустые поля таблицы SQL. А мне нужно проверить и скипнуть пустые поля ввода - textBoxN
0
|
|
|
14145 / 9374 / 1350
Регистрация: 21.01.2016
Сообщений: 35,306
|
||||||
| 14.11.2019, 06:29 | ||||||
|
Ворошитель, так бы сразу и сказали. Значит нужно так:
0
|
||||||
|
2 / 2 / 0
Регистрация: 06.06.2018
Сообщений: 49
|
|
| 14.11.2019, 13:27 [ТС] | |
|
Спасибо большое! Работает
Только теперь когда все поля пустые - делается выборка всей базы
0
|
|
|
14145 / 9374 / 1350
Регистрация: 21.01.2016
Сообщений: 35,306
|
|
| 14.11.2019, 14:34 | |
|
Ворошитель, ну логично. Как вы и просили.
0
|
|
| 14.11.2019, 14:34 | |
|
Помогаю со студенческими работами здесь
10
Поиск по сайту: не могу разобраться, как делать поиск по нескольким полям
Поиск по нескольким полям в БД Поиск по нескольким полям
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет
значение производной при заданном х
Логарифм записывается как: (x-2)log(x^2+2) -. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
|