Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
509 / 163 / 22
Регистрация: 04.10.2015
Сообщений: 646

Шире используйте собственные функции в запросах

23.02.2026, 01:19. Показов 1340. Ответов 21

Студворк — интернет-сервис помощи студентам
Это для тех, кто только начинает открывать для себя Access.
Многие кодеры, особенно новички, используют в качестве аргументов в запросах ссылки на элементы управлений в формах.
Например, как Forms![formName]![controlName]![Value]
Из многолетнего опыта могу утверждать, что это крайне неудобная форма подстановки параметров в запросы.
Во-первых, при разработке больших проектов, всегда можно потерять эти ссылки, если, например, вы решили переименовать форму или заменить ее другой.
Во-вторых, такая форма ссылок плохо читается, выглядит очень громоздко и не сразу понятно что означает параметр, если не открыть форму, на которую дана ссылка.

Вместо ссылок на элементы управления используйте в запросах функции, возвращающие значения этих элементов.
Для этого в стандартный модуль включите глобальные переменные, которые часто используются в проекте и добавьте функции их возвращающие.
Запись становится краткой и сразу понятной, что означает данный параметр.
Такие функции можно использовать не только в условиях к полям запросов, но даже для вывода данных в самих полях этих запросов.
Это позволяет выводить в них несвязанные между собой данные, то-есть связывать в одном запросе изначально "несвязуемое".
Пример, как это работает - в прикрепленном файле.
Примечание.
Для работы примера необходима ссылка на библиотеку Microsoft Office -версия офиса- Access database engine Object Library (ACEDAO.DLL)
Вложения
Тип файла: rar Prim.rar (180.7 Кб, 24 просмотров)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.02.2026, 01:19
Ответы с готовыми решениями:

Использование функции IIf в запросах
Имеется табличка с нулями, нужно с помощью функции IIf преобразовать таблицу так, чтобы значения,...

Функции и Процедуры во вложенных запросах
Добрый день. Считал, что функции во вложенных запросах выполняются 1 раз, результат вычисления...

Использование функций в запросах
Здравствуйте. Я хочу в запросе использовать функцию, чтобы определить статус заказа, но...

21
Эксперт MS Access
 Аватар для Eugene-LS
13225 / 5911 / 1518
Регистрация: 05.10.2016
Сообщений: 16,554
23.02.2026, 21:54
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от andris2 Посмотреть сообщение
Век Access по факту можно считать завершенным
Да, вы совершенно правы.
И не нужно так скромничать - Ваши решения гениальны, простите пожалуйста что не сказал вам этого раньше.
0
 Аватар для Silur
1370 / 290 / 16
Регистрация: 16.01.2014
Сообщений: 918
25.03.2026, 13:36
Цитата Сообщение от andris2 Посмотреть сообщение
Для обучения нужны хорошие книги, коих мало, а собственными разработками на российских просторах инета делиться никто не хочет.
Странно. А чем же тогда забиты 15 страниц ветки Делимся наработками
А на счёт книг - моя настольная - двухтомник Литвин, Гетц, Гунделой "Access 2002. Разработка приложений." Ничего более полезного и объемлющего я не встречал. Многое из двухтомника можно использовать и сейчас. К сожалению для новых версий ничего похожего нет (или я не встретил). Видел неплохие книги для 2010, 2013, 2016, Но они шли уже как дополнение к двухтомнику. Там я вычитывал только особенности и нововведения.

Добавлено через 4 минуты
Ну, а кое-какие книги можно скачать в ветке Документация по Access (книги, статьи, лекции и т.п.)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.03.2026, 13:36
Помогаю со студенческими работами здесь

Применение агрегатных функций в запросах
Добрый вечер, подскажите, пожалуйста, почему не работает данное условие отбора?? Мне нужно отобрать...

обработка NULL в запросах
Доброго всем дня. Есть программа, работающая с acces 98. Поставил SP6.Преобразовал базу в Acces...

iif в запросах
Помогите разобраться, где ошибка. iif(+365*100/>,Сумма амортизационных отчислений за месяц:...

Повторение записей в перекрестных запросах
при создании запроса из другого запроса и таблицы, появляются повторные записи. какой оператор...

Работа с Датой/временем в запросах
Допустим у нас есть год (в виде обычного числового формата). Необходимо посчитать количество дней...


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

Или воспользуйтесь поиском по форуму:
22
Ответ Создать тему
Новые блоги и статьи
Хитросплетение родственных связей пантеона греческих богов.
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. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru