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

Результат функции в условии запроса

27.08.2015, 17:28. Показов 757. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, очень хочу разобраться для себя в чем проблема на форме?
есть функция (funSumStr), которая преобразует столбец в строку, например:
А
1
2
3
4
5
преобразуется в 1;2;3;4;5. Я пытаюсь использовать это функцию в условии отбора, то есть делаю

MySQL
1
2
3
select столбецB
from таблица
where таблица.столбецА in (funSumStr)
по-моему должно получится

MySQL
1
2
3
select столбецB
from таблица
where таблица.столбецА in (1;2;3;4;5)
но не получается... Подскажите как передать результат функции в запрос или как подправить саму функцию, чтобы запрос ее понимал? Базу прилагаю.
Вложения
Тип файла: rar Prim.rar (21.1 Кб, 5 просмотров)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.08.2015, 17:28
Ответы с готовыми решениями:

Результат SQL-запроса вне функции...
Имеется такой скрипт: ... $inheritance_objects = mysql_db_query(DBName,'SELECT OBJECTID FROM objects WHERE OBJECT_TYPE = 6;'); ...

При выполнении функции результат должен показать, сколько строк в таблице TABLE при условии P1= MY_DATE
Здравствуйте помогите с запросом Знатоки плизз! Создать функцию с входным параметром P1(DATE), при выполнении данной функции результат...

Как результат запроса другого результата запроса запихнуть в массив?
Как результат запроса другого результата запроса запихнуть в массив? Здравствуйте, у меня такая вот небольшая головоломка, у меня есть...

8
1266 / 448 / 129
Регистрация: 21.03.2013
Сообщений: 1,210
27.08.2015, 18:19
может такой запрос лучше поможет
SQL
1
2
3
4
5
SELECT Code.code
FROM Code
WHERE Code.code IN (SELECT Fil.code
FROM Fil
WHERE Fil.slct=[ВведитеПараметр])
Параметр это -1 или 0
1
0 / 0 / 0
Регистрация: 11.09.2014
Сообщений: 5
27.08.2015, 18:30  [ТС]
Дело в том, что в примере этот способ отрабатывает очень быстро, но на той базе которую использую я, все происходит так медленно что я вообще сомневаюсь, а происходит ли что-то... Но вот когда я четко перечисляю, то что мне нужно по такому принципу:
MySQL
1
2
3
select столбецB
from таблица
where таблица.столбецА in (1;2;3;4;5)
не проходит даже секунды, но стоит сделать вложенный запрос и акс зависает конкретно и на долго...
0
1266 / 448 / 129
Регистрация: 21.03.2013
Сообщений: 1,210
27.08.2015, 18:38
конструкция in () предполагает что будут перечислены конкретные значения отбора
а ваша функция передает туда одно значения типа стринг - в этом и состоит нестыковка типов выражений

Добавлено через 1 минуту
если не хотите использовать вложеный запрос
используйте связанные запрос по определенным полям - он будет быстрее
1
0 / 0 / 0
Регистрация: 11.09.2014
Сообщений: 5
27.08.2015, 18:39  [ТС]
Ну я примерно так и подозревал, что передается 1;2;3;4;5 не 5 значений, а одно... А как-то можно это исправить? Я имею ввиду может функцию подправить:
PureBasic
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
Option Compare Database
Option Explicit
 
Public Function funSumStr(ByVal id As Long) As String
On Error GoTo Err_
 
Dim rst As DAO.Recordset
 
    'открываем запрос на чтение (параметр - dbOpenSnapshot)
    Set rst = CurrentDb.OpenRecordset( _
        "SELECT fil.code " & _
        "FROM fil " & _
        "WHERE fil.slct=" & id, _
    dbOpenSnapshot)
    
    If rst.RecordCount > 0 Then 'проверяем, чтобы не пустой запрос
        'делаем прбег по строкам запроса и собираем ФИО и группу допуска в одну строку
        Do While Not rst.EOF
            funSumStr = funSumStr & "; " & Nz(rst!code, "")
            rst.MoveNext
        Loop
        
        'удаляем первую запятую и пробел вначале (отсекаем 2 символа от начала)
        funSumStr = Mid(funSumStr, 3)
        
        'закрываем запрос
        rst.Close
        Set rst = Nothing
    End If
    
Exit Function
    
Err_:
    Err.Clear
End Function
0
1266 / 448 / 129
Регистрация: 21.03.2013
Сообщений: 1,210
27.08.2015, 18:45
примерно так
SQL
1
2
3
SELECT Code.code
FROM Fil INNER JOIN Code ON Fil.code = Code.code
WHERE Fil.slct=[введитепараметр]
Добавлено через 1 минуту
Цитата Сообщение от reddew Посмотреть сообщение
может функцию подправить:
это ложный путь - ваша функция открывает рекорсет и сначала пробегает по его значениям - это все время.

на больших базах - это всегда дольше чем просто запрос

Добавлено через 2 минуты
такая или подобная функция может использоваться при формировании запроса в ВБА
когда конектятся разные части запроса в одну строку но по моему это все равно не лучший путь
2
Эксперт MS Access
26825 / 14505 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
27.08.2015, 18:49
Попробуйте такой запрос
SQL
1
2
3
SELECT code.code
FROM code
WHERE eval(code.[code] & " In (" & funSumStr() & ")")
Ваша функция funSumStr изменена. Убрана ненужная проверка на "пустоту" рекордсета, удален параметр функции (???), вместо точки с запятой и пробела на выходе только запятая.
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
Public Function funSumStr() As String
On Error GoTo Err_
 
Dim rst As DAO.Recordset
 
    'открываем запрос на чтение (параметр - dbOpenSnapshot)
    Set rst = CurrentDb.OpenRecordset( _
        "SELECT fil.code " & _
        "FROM fil " & _
        "WHERE fil.slct", _
    dbOpenSnapshot)
    
    'делаем прбег по строкам запроса и собираем ФИО и группу допуска в одну строку
    Do While Not rst.EOF
        funSumStr = funSumStr & "," & Nz(rst!code, "")
        rst.MoveNext
    Loop
    
    'удаляем первую запятую и вначале (отсекаем 1 символ от начала)
    funSumStr = Mid(funSumStr, 2)
    
    'закрываем запрос
    rst.Close
    Set rst = Nothing
    
Exit Function
    
Err_:
    Err.Clear
End Function
На Кнопка2 в форме в процедуре выражение для обновления источника
Visual Basic
1
Me.qry.Form.RecordSource = Me.qry.Form.RecordSource
Вложения
Тип файла: rar Prim.rar (19.5 Кб, 5 просмотров)
2
1266 / 448 / 129
Регистрация: 21.03.2013
Сообщений: 1,210
27.08.2015, 18:53
Цитата Сообщение от mobile Посмотреть сообщение
удален параметр функции (???)
а как тогда выбрать те значение где выражение ЛОЖЬ?
1
Эксперт MS Access
26825 / 14505 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
27.08.2015, 19:02
Цитата Сообщение от boby104 Посмотреть сообщение
а как тогда выбрать те значение где выражение ЛОЖЬ?
Поле slct чекбокс, флажок. И может иметь только значения TRUE или FALSE. И незачем проверять труе на труе. Это лишняя проверка. Достаточно проверить сам чекбокс:
SQL
1
WHERE fil.slct
Вместо
SQL
1
WHERE fil.slct=TRUE
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.08.2015, 19:02
Помогаю со студенческими работами здесь

If в условии запроса
Вообщем помогите пожалуйста составить запрос Есть таблица Свободные ячейки это где стоит 0 Как эффективно сделать запрос UPDATE ...

результат запроса linq to sql содержит данные обеих таблиц, картографированных на классы. Я хочу результат присвоить в GridControl.DataSource
Здравствуйте! У меня есть две таблицы T1(id_t1(PK),name), T2(id_t2(PK), id_t1(FK), date) отображенных на классы при помощи linq to sql и...

Переменная в условии запроса
Добрый день.. Возникла небольшая трудность с синтаксисом а именно с вот этой Way переменной которую я пытаюсь воткнуть в условие ...

Результат запроса не в окне запроса, а на форме
а если я написал запрос на выборку,я могу в поисковой форме через нажатие на кнопку запустить этот запрос,но чтобы результат он мне выдал...

Результат запроса в новый столбец запроса
В общем есть запрос SELECT t.* FROM TASKS t WHERE t.TASKID in ( SELECT TASKID FROM TASKTRACKING tr WHERE tr.USERID =...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
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