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

Перенос переменной в строку с последующим созданием и выполнением запроса

16.06.2015, 13:02. Показов 1525. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день! Нужна подсказка по MS Access, сам уже пол дня бьюсь не могу понять в чем дело.
Имеется вот такая процедура по нажатию кнопки, динамически формирую строку запроса, вывожу её в сообщении, строка сформирована правильно. Далее пытаюсь создать запрос и поместить в него созданную строку и выполнить запрос, но ничего не получается, запрос не создается и как следствие не выполняется. Если переменной StrSql явно указать строку запроса типа "Select * from VVD", то все прекрасно работает, но мне как раз нужно чтобы в переменную StrSql попадал мой динамически созданный запрос.
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
33
34
35
36
37
38
39
40
Private Sub Кнопка159_Click()
 
Const sQ1 = "SELECT VVD.[Дата прибытия / убытия], VVD.[Въезд / Выезд], VVD.[Регистрация ТС] " + _
     "FROM VVD " + _
     "WHERE (((VVD.[Дата прибытия / убытия]) Between "
 
On Error Resume Next
 
Dim DateBegin$, DateEnd$, Napr$, RegTS$, sQ$
Dim StrSql As String
Dim db As Database
Dim qdf As QueryDef
Set db = CurrentDb
db.QueryDefs.Refresh
 
 
With [Forms]![VVD_Find]
    DateBegin = Format(![datastart], "\#mm\/dd\/yyyy\ h:m:s#")
    DateEnd = Format(![dataend], "\#mm\/dd\/yyyy\ h:m:s#")
    Napr = Nz(![Въезд/Выезд], "")
    RegTS = Nz(![РегТС], "")
End With
 
sQ = sQ1 + DateBegin + " AND " + DateEnd + ") "
sQ = sQ + IIf(Len(Napr) = 0, "", " AND ((VVD.[Въезд / Выезд]) ='" + Napr + "') ")
sQ = sQ + IIf(Len(RegTS) = 0, "", " AND ((VVD.[Регистрация ТС]) ='" + RegTS + "') ")
sQ = sQ + " ORDER BY VVD.[Дата прибытия / убытия]"
MsgBox sQ
 
For Each qdf In db.QueryDefs
    If qdf.Name = "Test" Then
        db.QueryDefs.Delete qdf.Name
    End If
Next qdf
StrSql = sQ
Set qdf = db.CreateQueryDef("Test", StrSql)
DoCmd.OpenQuery "Test", acViewNormal
qdf.Close
 
End Sub
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.06.2015, 13:02
Ответы с готовыми решениями:

Таймер с последующим выполнением
Всем привет, хочу спросить про код на СИ# В общем я хочу что бы после нажатия клавиши( она не должна отпускаться) произошло действие Я...

Поиск и выделение найденых ячеек с последующим выполнением программы
Всем доброго времени суток. Суть проблемы такова: надо данные со столбца V и W вставить в столбцы A и B (A и V хранят одинаковые значения)...

Добавление куска кода в RichTextBox с его последующим выполнением
Есть RichTextBox, в нем отображается текст, программа проводит манипуляции с текстом(код другой пограммы), изменяя его. Необходимо добавить...

4
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,933
Записей в блоге: 4
16.06.2015, 13:48
Лучший ответ Сообщение было отмечено Evgen39 как решение

Решение

лишняя скобка
SQL
1
"WHERE ((VVD.[Дата прибытия / убытия]) Between "
и возможно --форматы
SQL
1
2
DateBegin = Format(![datastart], "\#mm\/dd\/yyyy\ h:m:s\#")
    DateEnd = Format(![dataend], "\#mm\/dd\/yyyy\ h:m:s\#")
и запрос не будет работать, если не сообщить одну из дат
1
459 / 246 / 15
Регистрация: 29.10.2014
Сообщений: 1,084
16.06.2015, 14:02
Цитата Сообщение от Evgen39 Посмотреть сообщение
On Error Resume Next
Это как при поиске ошибки?
0
0 / 0 / 0
Регистрация: 16.06.2015
Сообщений: 2
16.06.2015, 14:15  [ТС]
Спасибо всем большое за помощь!
Проблема решена, затык был в лишней скобке. Лопухнулся так лопухнулся.
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,933
Записей в блоге: 4
16.06.2015, 14:28
не вставляйте куда попало строку On Error Resume Next
из-за этого вы не видели ошибку
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.06.2015, 14:28
Помогаю со студенческими работами здесь

Форма для корректировки скрипта, с последующим его выполнением
Есть некий лабиринт. Форма служит для задания координат. После заполнения формы, должна изменится строка в коде лабиринта отвечающая за...

Сбор рабочих листов из внешних файлов с последующим выполнением другого макроса
Использую прекрасный макрос с форума,-спасибо. Макрос умеет открывать много файлов "в один" - одну книгу-подшивку; рабочие листы...

Организовать создание односвязного списка с последующим созданием новых элементов данной структуры
Доброго вам здравия. Мне необходимо написать базу данных на Си с помощью односвязного списка. И вот у меня вопрос. Есть структура:...

Ошибка с выполнением запроса
При нажатии на время для выполнения запроса выскакивает такая ошибка procedure TTabbedwithNavigationForm.ListBox3ItemClick( const...

Тиканье часов паралельно с выполнением запроса
Уважаемые коллеги, помогите новичку, пож. задача такая. хочу показывать в lblTimer.Text время выполнения запроса паралельно с его...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru