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

цикл while

08.09.2011, 10:15. Показов 1734. Ответов 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
with QExpL do
   begin
   Close;
   Connection:=DM1.Conn1;
   with SQL do
   begin
   Clear;
   Add(' SELECT RS, FIO, CAST(IDCODE AS varchar) AS IDCODE ');
   Add(' FROM (SELECT TOP (100) PERCENT H.Num AS RS, ');
   Add(' CASE WHEN L.Name IS NULL THEN C.Name ELSE L.Name END AS FIO, ');
   Add(' L.IPN AS IDCODE ');
   Add(' FROM dbo._archHistoria AS H INNER JOIN ');
   Add('      dbo._archLgots AS L ON H.Num = L.Num ');
   Add(' AND H.Date1 = L.Date1 INNER JOIN ');
   Add('      dbo.Clients AS C ON H.Num = C.Num ');
   Add(' WHERE (L.Date1 = '+IntToStr(LDate)+')');
   Add(') AS K ');
   List:=TStringList.Create;
  try
    
    if cxCheckComboBox1.Value<>0 then
    begin
    NumItems := cxCheckComboBox1.Properties.Items.Count;
    for i := 0 to NumItems - 1 do
    begin
      CurrItem := cxCheckComboBox1.Properties.Items[i];
      if cxCheckComboBox1.States[i] = cbsChecked then
      if CurrItem.Tag<>0 then List.Add(IntToStr(CurrItem.Tag));
    end;  // for
    if List.Count>0 then
    begin
    Add(' WHERE (RS IN ');
    Add(' (SELECT L1.Num ');
    Add(' FROM dbo._archLgots AS L1 LEFT OUTER JOIN ');
    Add('      dbo.Clients AS C1 ON L1.Num = C1.Num INNER JOIN ');
    Add('      dbo.Areas A1 ON C1.Area=A1.Num ');
    Add(' WHERE (L1.Date1 = '+IntToStr(LDate)+') AND ');
    for j := 0 to List.Count-1  do
     begin
      Add(' (A1.id ='+List[j]+')');
      k:=j;
      while j<List.Count-1 do
        begin
        Add(' OR ');
        Inc(k);
        end;  // while k<List.Count-1
     end;  //for j := 0 to List.Count - 1 do
      Add('))');
    end; //if List.Count>0 then
    sMemo1.Lines.Clear;
    sMemo1.Lines.Add(QExpL.SQL.Text);
    end;
  finally
    List.Free;
  end;   // try
    Add(' ORDER BY RS ');
  end;
  Open;
  end;  // with QExpL
Есть checkcombobox в котором выбираю данные для фильтровки. Потом создаю StringList в который записываю список выбраных id. далее мне в запрос нужно добавить эти id через OR, но соответственно OR должно быть на 1 раз меньше, чем кол-во id в списке StringList. Вот если я выбираю два пункта из checkcombobox, то цикл добавляет правильное кол-во OR, а вот если выбираю 3 или более пунктов, то цикл while работает неправильно. Помогите, плз...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.09.2011, 10:15
Ответы с готовыми решениями:

Нормально ли для системы один и тот же цикл запускать цикл 20 раз в секунду с итерацией до 1000
Нормально ли для системы один и тот же цикл запускать цикл 20 раз в секунду с итерацией до 1000? Или это большая перегрузка для...

Цикл: как работает цикл в цикле
Не могу понять как работает цикл в цикле например: repeat begin lalalala if что-то1&lt;&gt;100 then begin lalalala2 ...

Создать программу по всем 3 видам циклов...цикл с параметром,цикл с условием,цикл,и цикл с предусловием...
Найти сумму чисел 1 в квадрате до 10 c квадрате...операцию возведению в степень не использовать учесть особенности получения квадратного...

1
Заблокирован
08.09.2011, 10:30
Я бы написал вот так:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
   if List.Count>0 then
    begin
    Add(' WHERE (RS IN ');
    Add(' (SELECT L1.Num ');
    Add(' FROM dbo._archLgots AS L1 LEFT OUTER JOIN ');
    Add('      dbo.Clients AS C1 ON L1.Num = C1.Num INNER JOIN ');
    Add('      dbo.Areas A1 ON C1.Area=A1.Num ');
    Add(' WHERE (L1.Date1 = '+IntToStr(LDate)+') AND ');
    k:=1;
    Add(' (A1.id ='+List[0]+')');
    while k < List.Count do
    begin
       Inc(k);
       Add(' OR ');
       Add(' (A1.id ='+List[k-1]+')');
    end;  // while k<List.Count
    Add('))');
    end; //if List.Count>0 then
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.09.2011, 10:30
Помогаю со студенческими работами здесь

Цикл с предусловием, цикл с постусловием и цикл с параметром
Объясните пожалуйста как делать эти циклы. У меня не получается. Можете сделать как на фото, или на подобии. Заранее спасибо)

Цикл: Используя цикл while, выведите на экран для числа 2 его степени от 0 до 20
Используя цикл while, выведите на экран для числа 2 его степени от 0 до 20. Возведение в степень в Python обозначается как **. Фрагмент...

Как реализовать бесконечный цикл While, но чтобы этот цикл не грузил процессор?
Допустим есть цикл: while (1) { ... } Как сделать так, чтобы бесконечный цикл не грузил процессор. Избавиться от...

Цикл: Вычислить значение выражения. Как вывести формулу и сделать цикл while?
Последовательно вводятся N целых чисел. Найти минимальное из них. #include&lt;stdio.h&gt; #include&lt;locale.h&gt; #include...

Цикл: Посчитать среднее арифметическое всех чисел в заданном диапазоне. Цикл while.
Напишите пожалуйста код для данной задачки с помощью цикла while Вывести числа в пользовательском диапазоне с шагом, указанным...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
BOINC: 22 года — и всё ещё работает
Programma_Boinc 12.03.2026
BOINC: 22 года — и всё ещё работает Дэвид Андерсон написал ретроспективу. Кратко: в 2001 году он ушёл из United Devices, где был CTO, и за несколько месяцев написал ядро BOINC — клиент, сервер,. . .
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта 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 На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru