|
1 / 1 / 0
Регистрация: 07.09.2021
Сообщений: 105
|
||||||
Неудовлетворительный результат поиска в ADOQuery методом Locate31.01.2022, 14:18. Показов 2606. Ответов 24
Добрый день уважаемые форумчане.
На форме имеется компонент DBLooukupCombobox. В него выводится уникальный уникальный список адресов из таблицы MSAccess. Пытаюсь через обработку событий OnChange текстового поля TEdit2 организовать быстрый поиск первого попавшего значения. Поиск работает с наполовину. Он находит значения расположенные до точки. А после точки пропускает. Это особенность поиска Locate, или я что-то не так делаю? Прошерстил форум и интернет, но насчет этой особенности ничего не накопал.
0
|
||||||
| 31.01.2022, 14:18 | |
|
Ответы с готовыми решениями:
24
Locate в ADOQuery
Метод Locate для поиска в БД Access |
|
|
|
| 01.02.2022, 11:36 | |
Сообщение было отмечено esgard как решение
Решение
если я ничего не путаю, то вас же не устраивает функциональность лукап комбо?
или уже норм? Насколько я понимаю, вы пытаетесь решить классическую задачу идентификации объекта по разным источникам методом синонимов. То же самое решают, когда заводят один и тот же товар по накладным от разных поставщиков, например. т.е. у нас есть какой-то эталонный справочник ID<--->строка и справочник синонимов, где много строк должны указывать на один и тот же ID из этого справочника ну и рабочая таблица, которая вместо исходной строки хранит ID из справочника. Тогда в лукапе мы должны собирать датасет по справочнику синонимов, соединенному(join!) с эталонным и этот датасет должен уточняться (фильтроваться) после ввода каждого следующего символа насколько я понимаю, лукап такой функциональности не даcт, даже если на него кинуть обработчик, потому что у него другая реакция на ввод, и надо ее как-то подавить. решением тут скорее всего будет вывод поверх модальной формы, где будет обычный edit и dbgrid при вводе в Edit происходят все более точные запросы, в гриде видим результат. двойным кликом по гриду закрываем форму и проставляем в нужное поле эталонный ID. А само поле тогда как раз может быть lookup полем на эталонный справочник а параметры это просто способ 1) не делать ошибки в выражениях 2) не заставлять сервер бесконечно заново парсить одну и ту же SQL строку
1
|
|
|
1 / 1 / 0
Регистрация: 07.09.2021
Сообщений: 105
|
||
| 01.02.2022, 15:36 [ТС] | ||
|
0
|
||
|
1 / 1 / 0
Регистрация: 07.09.2021
Сообщений: 105
|
||||||
| 01.02.2022, 17:20 [ТС] | ||||||
|
Не пойму в чем дело. Фильтрация отрабатывает вроде бы нормально. Но возникла какая то непонятная проблема с передачей значения выделенной строки. Причем иногда передается правильно, а иногда нет.
0
|
||||||
|
1 / 1 / 0
Регистрация: 07.09.2021
Сообщений: 105
|
|||||||
| 02.02.2022, 10:56 [ТС] | |||||||
|
Путем многочисленных проб и ошибок было выяснено что всю малину портит собственный быстрый поиск компонента DBLookUpCombobox. О чем вы и писали:
А вот с методами подавления тоже пришлось помучиться. Пробовал отключать комбобокс, пробовал передавать значения через глобальную переменную, задумался уже о свойстве KeyPreview главной формы, но в итоге пришел к этому:
0
|
|||||||
| 02.02.2022, 10:56 | |
|
Помогаю со студенческими работами здесь
25
Проблема с методом Locate() Поиск методом Locate
Поиск методом Locate: маски Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
[golang] Алгоритм «Хак Госпера»
alhaos 17.05.2026
Алгоритм «Хак Госпера»
Хак Госпера (Gosper's Hack) — алгоритм нахождения следующего по величине числа с тем же количеством установленных бит.
Придуман Биллом Госпером в 1970-х, опубликован в. . .
|
Рисование бинарного древа до 6-го колена на js, svg.
russiannick 17.05.2026
<svg width="335" height="240" viewBox="0 0 335 240" fill="#e5e1bb">
<style>
<!]>
</ style>
<g id="bush">
</ g>
</ svg>
function fn(){
let rost;/ / высота древа
let xx=165,yy=210,w=256;
|
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов,
содержащихся в реализации модуля. По-умолчанию все члены модуля доступны:
module Foo
let x = 10
let boo () = printfn "boo"
. . .
|
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции.
<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible". . .
|
|
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов.
import "math"
func angleClock(hour int, minutes int) float64 {
. . .
|
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo
https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html
и его же старой инструкции по установке Lazarus с gtk2. . .
|
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер.
Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
|
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта
Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
|