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

Запрос SELECT с выводом повторных значений

05.03.2019, 01:49. Показов 4120. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток, уважаемые форумчане!

Прошу помощи и совета по своему вопросу.
Сразу оговорюсь, что в составлении SQL запросов, да и в общем в SQL я не силен, но кое что понять способен
У меня такая проблема. Есть небольшой скрипт в VBA, в процессе которого выполняется запрос SELECT в базу Access (.accdb), в результате которого в эксель выводится информация из БД (напротив искомых данных, в той же строке), которая удовлетворяет запросу. Все работает хорошо, все попадает в нужные ячейки. Пример запроса:

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
    SET cn = CreateObject("ADODB.Connection")
    cn.Open "Provider=Microsoft.ACE.OLEDB.12.0; Data Source= db1.accdb; Data Source=" & DBFullName & ";"
 
 iRows = ThisWorkbook.Sheets("Äàííûå").Cells(ROWS.Count, 1).End(xlUp).Row
 FOR i = 3 TO iRows
    SET rs = CreateObject("ADODB.Recordset")
    
    
    rs.Open "SELECT Code,Model,Kolichestvo FROM Baza WHERE ID = '" & Range("A" & i) & "'", cn, , , adCmdText
    
        IF NOT (rs.BOF OR rs.EOF) THEN
            Sheets(1).Range("B" & i) = rs.Fields("Code").Value
            ThisWorkbook.Sheets(1).Range("C" & i) = rs.Fields("Model").Value
            ThisWorkbook.Sheets(1).Range("D" & i) = rs.Fields("Kolichestvo").Value
        END IF
NEXT i
Проблема возникает в тот момент, когда в БД появляются значения ID, которые повторяются два или более раз. В этом случает SELECT ищет и выводит только первое совпадение, в то время, когда нужно получить инфу по всем совпадениям ID.

Можно ли подкорректировать запрос SELECT так, чтобы он сохранял в рекордсет все совпадения, даже если искомое значение (ID) повторяется и чтобы если найдено ID в БД больше одного раза.
Примерное описание на примере так же приложил.

Заранее спасибо за помощь!
Вложения
Тип файла: zip Пример.zip (30.9 Кб, 2 просмотров)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.03.2019, 01:49
Ответы с готовыми решениями:

Select запрос C# с выводом значений по ID из сессии
Здравствуйте, очень прошу помощи! У меня есть таблица созданная процедурой INCERT CREATE PROCEDURE forInsert_ObrasheniyeAdress ...

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

Перекрестный запрос с выводом множества значений
Есть таблица из трех столбцов: Семейство, Местонахождение, Ссылка на публикацию (для наглядности привожу кусок из реальной базы). ...

4
4089 / 1469 / 401
Регистрация: 07.08.2013
Сообщений: 3,672
05.03.2019, 08:01
Лучший ответ Сообщение было отмечено Hemilton1 как решение

Решение

это не запрос виноват
это код такой
что берется только первое значение
затык вот тут
Visual Basic
1
2
3
4
5
6
7
8
9
FOR i = 3 TO iRows ' i переменная цикла 
    .....    
        IF NOT (rs.BOF OR rs.EOF) THEN ' если рекордсет не пустой то
            Sheets(1).Range("B" & i) = rs.Fields("Code").Value ' то в ячейку B(i) подставить значение 
            ThisWorkbook.Sheets(1).Range("C" & i) = rs.Fields("Model").Value
            ThisWorkbook.Sheets(1).Range("D" & i) = rs.Fields("Kolichestvo").Value
        END IF
        ' и все - это один раз всего а если рекордсет вернул несколько строк то повтора не будет - данные закинутся только из первой записи
NEXT i
Добавлено через 1 час 18 минут
и самое главное
а что надо сделать если запрос вернул несколько записей?

Добавлено через 3 часа 20 минут
наконец-то скачал файлик
можно подправить так
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
IF NOT (rs.BOF OR rs.EOF) THEN ' если рекордсет не пустой то
            rs.movelast: rs.movefirst' гоняем рекордсет взад вперед - нужно для правильного подсчета количества записей
            Sheets(1).Range("B" & i) = rs.Fields("Code").Value 
            ThisWorkbook.Sheets(1).Range("C" & i) = rs.Fields("Model").Value
            ThisWorkbook.Sheets(1).Range("D" & i) = rs.Fields("Kolichestvo").Value
             if rs.recordcount>1 then' проверяем количество записей которое вернул рекордсет
                       for j=2 to rs.Recordcount ' запускаем цикл для прохода по записям
                                 rs.movenext' передвигаем фокус рекордсета на следующую запись
                                 ThisWorkbook.Sheets(1).Cells(i,3+j) = rs.Fields("Kolichestvo").Value ' заносим значение в ячейку
                       next j
             end if
END IF
1
0 / 0 / 0
Регистрация: 05.03.2019
Сообщений: 18
05.03.2019, 17:01  [ТС]
Спасибо за ответ!
В Вашем примере у меня возникает ошибка: "Набор строк не поддерживает обратную выборку".
Ошибка возникает тут:
Visual Basic
1
 rs.movelast: rs.movefirst ' гоняем рекордсет взад вперед - нужно для правильного подсчета количества записей
Подозреваю, что у меня либо запрос составлен неправильно, либо что-то с базой?
0
4089 / 1469 / 401
Регистрация: 07.08.2013
Сообщений: 3,672
06.03.2019, 05:00
Лучший ответ Сообщение было отмечено Hemilton1 как решение

Решение

вот это
Visual Basic
1
rs.Open "SELECT Code,Model,Kolichestvo FROM Baza WHERE ID = '" & Range("A" & i) & "'", cn, , , adCmdText
напишите так
Visual Basic
1
rs.Open "SELECT Code,Model,Kolichestvo FROM Baza WHERE ID = '" & Range("A" & i) & "'", cn, 3, 3
1
0 / 0 / 0
Регистрация: 05.03.2019
Сообщений: 18
06.03.2019, 19:55  [ТС]
Цитата Сообщение от snipe Посмотреть сообщение
напишите так


Visual Basic
1
rs.Open "SELECT Code,Model,Kolichestvo FROM Baza WHERE ID = '" & Range("A" & i) & "'", cn, 3, 3
Работает так, как нужно!
Огромное Вам спасибо за оказанную помощь!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.03.2019, 19:55
Помогаю со студенческими работами здесь

Запрос SELECT c игнорирование массива значений
Как в VBA сделать запрос с помощью оператора SELECT который игнорировал бы целый массив (динамический) значений?

запрос select а коде VB возвращает нуль значений
Код(картинка, кода мало)...

Как сделать запрос из двух таблиц с использованием оператора Select с заменой значений столбцов?
Всем доброго времени суток! Я сейчас самостоятельно изучаю mysql и мне нужно выполнить практическое задание, вся информация под...

Запрет ввода повторных значений в поля подчиненных форм
Здравствуйте. В базе есть главная форма (A), содержащая подчиненные формы (B и C). Есть ли способ запретить ввод повторных значений в...

Как отображать определенные данные в <select> в зависимости от значений в другом <select>?
Здравствуйте! У меня на страницу есть два &lt;select&gt;. В каждом из них располагаются даты в формате dd.mm.yyyy. &lt;select...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru