Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
0 / 0 / 0
Регистрация: 05.08.2010
Сообщений: 99

Как проверить какое значение вернул запрос ?

30.04.2011, 11:27. Показов 3406. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Возможно ли проверить какое значение вернул запрос ?
Допустим имеется простенький запрос с текстовым полем

SQL
1
2
SELECT Table1.Field
FROM Table1;
Нужно выполнить то или иное действие если 'Field' возвращает хотя-бы одно значение 'home' - примерно так:

Visual Basic
1
2
if "Table1.Field" = "home" then
end if
спасибо
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.04.2011, 11:27
Ответы с готовыми решениями:

Как проверить, вернул ли запрос что-либо?
Здравствуйте! Помогите пожалуйста организовать условие: Если 'запрос' не пустой то... запрос выполнился выше и имеет название q4 ...

Проверить вернул ли что-то запрос с бд
Как проверить, в результате выполнения запроса было что-то возвращено? resultSet = statement.executeQuery("SELECT * FROM account...

Golang postgres проверить если запрос не вернул записей
Есть такой код: func ModelLoginAuth(id, pwd string) (*MedReg) { //Cписок мед регистраторов rows := db.Select(`SELECT fam,...

10
118 / 118 / 10
Регистрация: 12.05.2010
Сообщений: 1,207
30.04.2011, 13:44
Visual Basic
1
2
3
4
5
6
7
8
9
Dim table As Recordset
 
Set table = CurrentBD.OpenRecordset("SELECT Table1.Field FROM Table1;", dbOpenDynaset)
  If Not table.EOF Then
    If table!Field = "home" Then
      ...
    End If
  End If
End If
0
118 / 118 / 10
Регистрация: 12.05.2010
Сообщений: 1,207
30.04.2011, 13:45
Прошу прощения: последний End If - лишний.
0
0 / 0 / 0
Регистрация: 05.08.2010
Сообщений: 99
09.05.2011, 14:22  [ТС]
У меня такая конструкция срабатывает только если требуемый 'номе' в запросе стоит на 1 месте, а что делать если он оказался на 2 или вообще где нибудь в конце ?
0
4 / 4 / 0
Регистрация: 15.09.2010
Сообщений: 228
09.05.2011, 15:35
>>> Нужно выполнить то или иное действие если 'Field' возвращает хотя-
>>> бы одно значение 'home'

If DCount('*', 'ИмяЗапроса', 'Field = 'Home'')

ЗЫЖ Field - не самое удачное имя поля...
0
0 / 0 / 0
Регистрация: 05.08.2010
Сообщений: 99
11.05.2011, 19:15  [ТС]
Спасибо но DCount в моем случае не подходит мой запрос динамический - формируется в зависимости от выбора в листбоксе.
Что-бы было понятнее ситуация такая:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
Dim i As Integer
repSource = ""
 
 For i = 0 To List1.ListCount - 1
   If List1.Selected(i) Then
      If repSource > "" Then repSource = repSource & ","
         repSource = repSource & CStr(List1.ItemData(i))
      End If
 Next
 
repSource = "SELECT BatchReport.BatchReportID, BatchReport.Date, Order.OrderNumber, Order.ResNum, Order.OrderedAmount, BatchReport.HotWater, BatchReport.HotWaterAct, BatchReport.ColdWater, BatchReport.ColdWaterAct, BatchReport.AddWater, BatchReport.LVWater, BatchReport.FixWater, BatchReport.wc, BatchReport.wcAct, BatchReport.MixingTime, Order.Temp, Order.Testi FROM [Order] INNER JOIN BatchReport ON Order.OrderID = BatchReport.OrderID WHERE BatchReportID in (" & repSource & ")"
Собственно надо проверить чтобы небыло никаких 'home' в 'Order.OrderNumber'
0
118 / 118 / 10
Регистрация: 12.05.2010
Сообщений: 1,207
11.05.2011, 20:45
Так чем не подходит 20.02.2005 13:07?
0
0 / 0 / 0
Регистрация: 05.08.2010
Сообщений: 99
11.05.2011, 21:25  [ТС]
прикручивая к вышеуказанному коду:

Visual Basic
1
2
3
4
5
6
7
8
Dim rst As Recordset
Set rst = CurrentDb.OpenRecordset(repSource, dbOpenDynaset)
 
If Not rst.EOF Then
    If rst!OrderNumber = 'home' Then
        MsgBox "You have chosen home.", vbInformation
    End If
End If
Неподходит тем, что если в результате запроса 'home' окажется не в 1 строке данная конструкция не работает (не находит 'номе' в середине или конце запроса)
0
4 / 4 / 0
Регистрация: 15.10.2008
Сообщений: 282
11.05.2011, 22:11
A Find метoд рекoрсетa чем не пoдхoдит?
0
0 / 0 / 0
Регистрация: 05.08.2010
Сообщений: 99
11.05.2011, 22:17  [ТС]
Find не пробовал - нарисуйте простенький примерчик. Спасибо
0
0 / 0 / 0
Регистрация: 05.08.2010
Сообщений: 99
11.05.2011, 23:07  [ТС]
спасибо Mike за намек .
Вот что у меня получилось, работает как надо - ищет и в середине и в начале и в конце. Прошу поправить если заметите какие другие ошибки - т.к. изучаю VBA исключительно методом тЫка.
Visual Basic
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
Dim i As Integer
Dim rst As Recordset, dbs As Database
Dim strCriteria As String
 
Set dbs = CurrentDb
strCriteria = "[OrderNumber] = 'home'"
repSource = ""
 
    For i = 0 To List1.ListCount - 1
        If List1.Selected(i) Then
            If repSource > "" Then repSource = repSource & ","
            repSource = repSource & CStr(List1.ItemData(i))
        End If
    Next
 
repSource = "SELECT BatchReport.BatchReportID, BatchReport.Date, Order.OrderNumber, Order.ResNum, Order.OrderedAmount, BatchReport.HotWater, BatchReport.HotWaterAct, BatchReport.ColdWater, BatchReport.ColdWaterAct, BatchReport.AddWater, BatchReport.LVWater, BatchReport.FixWater, BatchReport.wc, BatchReport.wcAct, BatchReport.MixingTime, Order.Temp, Order.Testi FROM [Order] INNER JOIN BatchReport ON Order.OrderID = BatchReport.OrderID WHERE BatchReportID in (" & repSource & ")"
 
Set rst = dbs.OpenRecordset(repSource, dbOpenDynaset)
rst.FindFirst strCriteria
 
If rst.NoMatch Then
    MsgBox "Not found home."
Else
    Do Until rst.NoMatch
        Debug.Print rst!OrderNumber
        rst.FindNext strCriteria
    Loop
    MsgBox "Found home."
End If
 
rst.Close
Set dbs = Nothing
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.05.2011, 23:07
Помогаю со студенческими работами здесь

Sqlite, как проверить есть ли результат и какое значение
Извиняюсь если вопрос глупый, делаю запрос по одному из полей таблицы. На выходе должен получить поле id, или ничего (то есть, записи с...

Как проверить какое значение храниться в поле таблицы БД?
Добрый день. Есть таблица table в БД с полем privilege в котором по умолчанию хранится значение 0 как проверить какое значение...

Как проверить, пустое ли поле вернул ADOQuery
Товарищи, помогите, плз! Есть ADOQuery, который должен вернуть 4 столбца с данными из базы Access.. Может случиться, что один из...

Как узнать вернул ли что-то запрос ?
Здравствуйте! Такая задача: я вводу в поле слово и хочу проверить есть ли такое слово в таблице, если есть то выводится сообщение что...

Как узнать, что запрос ни чего не вернул?
Как узнать, что запрос Query1->SQL->Add("SELECT.... ни чего не вернул?


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
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 На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru