Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 20.05.2013
Сообщений: 7

Обычный поиск и поиск с параметром

20.05.2013, 23:57. Показов 981. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как совместить 2 поиска в один(при нажатии 1 кнопки и искали по всем полям)... никак не хотят вместе сортировать, а по отдельности вполне себе рабочие...

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
procedure TForm1.Button1Click(Sender: TObject);
 var s1,s2: real;
n: integer;
begin
ADOQuery1.Active := False;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM main');
if (Length(ComboBox2.Text) > 0) or
   (Length(ComboBox5.Text) > 0) or
   (Length(datetostr(DateTimePicker1.date)) > 0) or
   (Length(datetostr(DateTimePicker2.date)) > 0) or
   (Length(ComboBox4.Text) > 0) or
   (Length(Edit5.Text) > 0) or
   (Length(Edit6.Text) > 0) or
   (Length(Edit7.Text) > 0) or
   (Length(Edit11.Text) > 0) or
   (Length(ComboBox3.Text) > 0) then
      begin
 
       ADOQuery1.SQL.Add('where kompania LIKE' + #39 + '%' + ComboBox2.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('transport_kompani LIKE' + #39 + '%' + ComboBox5.Text + '%' + #39 +'AND');
       if ComboBox3.Text='Çà íàø ñ÷¸ò' then
          begin
            ADOQuery1.SQL.Add('schet LIKE' + #39 + '%' + ComboBox3.Text + '%' + #39 + 'AND');
            dbgrid1.Columns[16].Visible:=false;
            dbgrid1.Columns[17].Visible:=false;
         end
       else
         begin
            ADOQuery1.SQL.Add('schet LIKE' + #39 + '%' + ComboBox3.Text + '%' + #39 + 'AND');
            dbgrid1.Columns[16].Visible:=true;
            dbgrid1.Columns[17].Visible:=true;
         end;
       if DateTimePicker1.format <> ' ' then
         begin
           ADOQuery1.SQL.Add('data_zabora LIKE' + #39 + '%' + datetostr(DateTimePicker1.date) + '%' + #39 + 'AND');
           DateTimePicker1.format:=' ';
         end;
       if DateTimePicker2.format <> ' ' then
         begin
           ADOQuery1.SQL.Add('data_dostavki LIKE' + #39 + '%' + datetostr(DateTimePicker2.date) + '%' + #39 + 'AND');
           DateTimePicker2.format:=' ';
         end;
       ADOQuery1.SQL.Add('menedjer_zak LIKE' + #39 + '%' + ComboBox4.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('adres_vygr LIKE' + #39 + '%' + Edit5.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('tip_mashin LIKE' + #39 + '%' + Edit6.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('ves_gruza LIKE' + #39 + '%' + Edit7.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('Summa_dostavki LIKE' + #39 + '%' + Edit11.Text + '%' + #39);
 
       ADOQuery1.Active:= True;
     end
   else
     begin
       ADOQuery1.Active:= true;
       ADOQuery1.First;
     end;
 
TNumericField(ADOQuery1.FieldByName('Summa_dostavki')).DisplayFormat := '#.00p';
TNumericField(ADOQuery1.FieldByName('ves_gruza')).DisplayFormat := '#êã';
ADOQuery1.Open;
label17.Caption:='Найдено записей: ' + inttostr(adoquery1.RecordCount);
 
s1:=0;
s2:=0;
ADOquery1.First;
for n:=1 to ADOquery1.RecordCount do begin
s1:= s1 + ADOquery1.FieldByName('ves_gruza').AsFloat;
s2:= s2 + ADOquery1.FieldByName('summa_dostavki').AsFloat;
ADOquery1.Next;
end;
Label35.Caption :='Общий вес: '+FloatToStr(s1) + 'кг';
Label37.Caption :='Общая сумма: '+FloatToStr(s2) + 'р.';
 
end;

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
procedure TForm1.Button15Click(Sender: TObject);
begin
 
ADOQuery1.Active:=false;
ADOQuery1.Sql.clear;
ADOQuery1.Sql.Add('select * from main');
ADOQuery1.Sql.Add('where data_zabora BETWEEN :a and :b');
ADOQuery1.Parameters.ParamByName('a').Value:=dateof(DateTimePicker7.Date);
ADOQuery1.Parameters.ParamByName('b').Value:=dateof(DateTimePicker8.Date);
ADOQuery1.Active:=true;
 
end;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.05.2013, 23:57
Ответы с готовыми решениями:

Поиск по Ini-файлу и вывод, как поиск Гугла
В общем такой вопрос, вот в ини файле есть данные. Как реализовать вывод их как в поиске гугл. Мы пишем начало записи и он предлагает...

Изменить поиск, что бы осуществлялся поиск цифр, а не текста
Доброго времени суток проблема такова есть код на поиск текста из БД как заменить чтобы он искал не текст а цифры s1:=Edit1.Text; s2:=...

Поиск в ADoquery, Delphi, поиск в базе данных
Доброго времени суток многоуважаемые пользователи данного сайта! Есть очень глупая проблема, с которой я, к сожалению, справиться не...

4
 Аватар для Waddonator
969 / 644 / 97
Регистрация: 01.11.2012
Сообщений: 1,447
21.05.2013, 11:08
Цитата Сообщение от JlOKOMOTNB Посмотреть сообщение
Как совместить 2 поиска в один(при нажатии 1 кнопки и искали по всем полям)... никак не хотят вместе сортировать
Вы ищите или сортируете?
добавьте поиск по дате в первоначальный поиск на Button1 (допустим добавьте на форму CheckBox и обрабатывайте его - если нажат, то ищем еще и по дате, если не нажат, то по дате не ищем). Добавьте на форму CheckBox и вставьте код перед 52 строкой (ADOQuery1.Active:= True:
Delphi
1
if CheckBox1.Checked then ADOQuery1.Sql.Add('and data_zabora BETWEEN :a and :b');
0
0 / 0 / 0
Регистрация: 20.05.2013
Сообщений: 7
22.05.2013, 15:42  [ТС]
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
procedure TForm1.Button1Click(Sender: TObject);
 var s1,s2: real;
n: integer;
begin
ADOQuery1.Active := False;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM main');
 
if (Length(ComboBox2.Text) > 0) or
   (Length(ComboBox5.Text) > 0) or
   (Length(datetostr(DateTimePicker1.date)) > 0) or
   (Length(datetostr(DateTimePicker2.date)) > 0) or
   (Length(ComboBox4.Text) > 0) or
   (Length(Edit5.Text) > 0) or
   (Length(Edit6.Text) > 0) or
   (Length(Edit7.Text) > 0) or
   (Length(Edit11.Text) > 0) or
   (Length(ComboBox3.Text) > 0) then
      begin
 
       ADOQuery1.SQL.Add('where kompania LIKE' + #39 + '%' + ComboBox2.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('transport_kompani LIKE' + #39 + '%' + ComboBox5.Text + '%' + #39 +'AND');
       if ComboBox3.Text='Çà íàø ñ÷¸ò' then
       begin
       ADOQuery1.SQL.Add('schet LIKE' + #39 + '%' + ComboBox3.Text + '%' + #39 + 'AND');
       dbgrid1.Columns[16].Visible:=false;
       dbgrid1.Columns[17].Visible:=false;
       end
       else
       begin
       ADOQuery1.SQL.Add('schet LIKE' + #39 + '%' + ComboBox3.Text + '%' + #39 + 'AND');
       dbgrid1.Columns[16].Visible:=true;
       dbgrid1.Columns[17].Visible:=true;
       end;
       if DateTimePicker1.format <> ' ' then
       begin
       ADOQuery1.SQL.Add('data_zabora LIKE' + #39 + '%' + datetostr(DateTimePicker1.date) + '%' + #39 + 'AND');
       DateTimePicker1.format:=' ';
       end;
       if DateTimePicker2.format <> ' ' then
       begin
       ADOQuery1.SQL.Add('data_dostavki LIKE' + #39 + '%' + datetostr(DateTimePicker2.date) + '%' + #39 + 'AND');
       DateTimePicker2.format:=' ';
       end;
       ADOQuery1.SQL.Add('menedjer_zak LIKE' + #39 + '%' + ComboBox4.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('adres_vygr LIKE' + #39 + '%' + Edit5.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('tip_mashin LIKE' + #39 + '%' + Edit6.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('ves_gruza LIKE' + #39 + '%' + Edit7.Text + '%' + #39 +'AND');
       ADOQuery1.SQL.Add('Summa_dostavki LIKE' + #39 + '%' + Edit11.Text + '%' + #39);
 
   if DateTimePicker7.format <> ' ' then
       begin
        ADOQuery1.Sql.Add('and data_zabora BETWEEN :a and :b');
        ADOQuery1.Parameters.ParamByName('a').Value:=dateof(DateTimePicker7.Date);
        ADOQuery1.Parameters.ParamByName('b').Value:=dateof(DateTimePicker8.Date);
       end;
 
       ADOQuery1.Active:= True;
     end
   else
     begin
       ADOQuery1.Active:= true;
       ADOQuery1.First;
     end;
Вставил вот так и вновь ищет либо только период либо остальной поиск, но по одной кнопке... когда пытаюсь искать по периоду и компании к примеру выдает ошибку на параметр а и b

Добавлено через 2 минуты
Куда мне деть эти 2 строчки с параметром что бы все было по маслу... уже как только не пробывал(

Delphi
1
2
ADOQuery1.Parameters.ParamByName('a').Value:=dateof(DateTimePicker7.Date);
ADOQuery1.Parameters.ParamByName('b').Value:=dateof(DateTimePicker8.Date);
0
 Аватар для Waddonator
969 / 644 / 97
Регистрация: 01.11.2012
Сообщений: 1,447
22.05.2013, 15:56
Цитата Сообщение от JlOKOMOTNB Посмотреть сообщение
выдает ошибку на параметр а и b
попробуйте заменить на:
Delphi
1
2
3
ADOQuery1.Parameters.Refresh;
ADOQuery1.Parameters[0].Value:=dateof(DateTimePicker7.Date);
ADOQuery1.Parameters[1].Value:=dateof(DateTimePicker8.Date);
1
0 / 0 / 0
Регистрация: 20.05.2013
Сообщений: 7
22.05.2013, 15:59  [ТС]
Опа) спасибо все нормуль... не очень втыкаю в эти параметры...

я уж думал наглядно видео записать и выложить)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.05.2013, 15:59
Помогаю со студенческими работами здесь

Поиск в базе данных (поиск далее)
Добрый вечер! Нужна ваша помощь. Делаю поиск по базе, использую компонент AdoTable. В базе есть Одинаковые строки, нужно чтобы при нажатии...

Поиск, частичный поиск и фильтрация в бд
Искал на форуме, но то что нужно мне не нашел. Бд подключал через DBGrid ADOQuery ADOConnection DataSource. На главной форме находится...

Поиск строки с заданным параметром
Помогите найти ошибку в коде. задание описано ниже. Код вроде неплох, но работает не всегда ( #include &lt;stdio.h&gt; #include...

запрос с параметром из формы- поиск
Здравствуйте ! я новичок в Access, нужно сделать простой запрос с параметром из формы, который производит поиск по тэгу. Поиск по автору...

Не получается сделать поиск с параметром Fuzzy
Мне необходимо реализовать агент с параметром FUZZY. Читал дизайнерский хелп, сделал тестовый агент, но он не работает, выдается сообщение...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru