Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
0 / 0 / 0
Регистрация: 16.02.2011
Сообщений: 6

Загрузка в datatable несколькими запросами (MS Access)

03.04.2012, 11:58. Показов 1998. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть БД в MS Access. Мне нужно получить из нее данные следующими запросами
SQL
1
2
3
4
SELECT TOP 3
 FROM MyTable 
WHERE MyTable.Category = @CategoryID
ORDER BY Rnd(id)
Таких запросов будет штук 8 и все это нужно запихнуть в 1 datatable. Как лучше это сделать?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.04.2012, 11:58
Ответы с готовыми решениями:

Проблемы с несколькими запросами...
Скажем, на PHP есть код: $per='CREATE TABLE ololo(id int(4) NOT NULL PRIMARY KEY auto_increment); insert into kykyky(lolo)...

Работа с несколькими запросами по COM-порту
Добрый день. Возник вопрос такого характера. Есть запрос на устройство который связан по com-порту, запрос состоит из 8 байт в ответ...

QuickReport и работа с несколькими запросами
Подскажите пожалуйста. У меня есть запрос по которому выбираются данные и по результату этого запроса выбираются данные в другом запросе....

7
1057 / 864 / 195
Регистрация: 31.03.2010
Сообщений: 2,521
03.04.2012, 12:07
использовать один запрос используя union all

а почему 8 запросов? скажите зачем вам 8 запросов, может их можно переделать в 1 запрос
0
0 / 0 / 0
Регистрация: 16.02.2011
Сообщений: 6
03.04.2012, 12:10  [ТС]
@categoryID будет везде разный.
UNION не подходит поскольку он принимает только 1 ORDER BY (для 1го запроса).
0
1057 / 864 / 195
Регистрация: 31.03.2010
Сообщений: 2,521
03.04.2012, 12:15
order by работает если его добавить в самый конец запроса(union all создает одну таблицу), а order by будет обратабывать результирующую таблицу.

ну а в вашем случае просто можно использовать

T-SQL
1
WHERE MyTable.Category in (@Id1, @Id2...)
или можно использовать string.Format:
C#
1
2
3
4
5
string str = id1, id2, id3 // где id - Значения и :
string query = string.Format(   @"SELECT
     FROM MyTable
    WHERE MyTable.Category in ({0})
    ORDER BY Rnd(id)", str);
0
0 / 0 / 0
Регистрация: 16.02.2011
Сообщений: 6
03.04.2012, 12:21  [ТС]
Вы немного меня не поняли:
Мне нужно получить 3 случайных(!!!) записи 1й категории, 3 случайных записи 2й и тд.
Ваш запрос вернет мне всю таблицу (если я укажу все категории) в случайном порядке.
0
1057 / 864 / 195
Регистрация: 31.03.2010
Сообщений: 2,521
03.04.2012, 12:43
тогда используйте union all и order by в самом конце и все
0
0 / 0 / 0
Регистрация: 16.02.2011
Сообщений: 6
03.04.2012, 12:48  [ТС]
Тогда запрос вернет 1е 3 записи 1й категории, 1е 3 записи 2й и тд. в случайном порядке
0
1057 / 864 / 195
Регистрация: 31.03.2010
Сообщений: 2,521
03.04.2012, 14:02
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
DataTable Categories = new DataTable();
SqlDataAdapter ada = new SqlDataAdapter("Select Category, Count(*) from MyTable group by Category", connection);
ada.Fill(Categories);
DataTable Resault = new DataTable();
ada.SelectCommand("Select top 3 from MyTable where not exit (Select top @f from MyTable where Category = @c) and Category=@c");
ada.SelectCommand.Parameters.Add("@f", OleDbType.Int);
ada.SelectCommand.Parameters.Add("@c", OleDbType.Int);
Random r = new Random();
 
foreach(DataRow row in Categories.Rows)
{
if((int)row[1]<4)
{
ada.SelectCommand.Parameters["@f"].Value = 0;
}
else {
      ada.SelectCommand.Parameters["@f"].Value = r.Next((int)row[1]-1);
}
ada.SelectCommand.Parameters["@c"].Value = row[0];
ada.Fill(Resault);
}
на MS Sql работает как с acsess не знаю точно
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.04.2012, 14:02
Помогаю со студенческими работами здесь

Создание процедуры с несколькими select запросами
Доброго времени суток! Нужно создать процедуру которая возвращает результаты нескольких запросов select. Вот мои безрезультатные...

Можно ли продвигать главную страницу несколькими запросами
Сначало сделал, а теперь решил узнать...((

VB+Access: проблема с запросами
Суть вопроса: БД на Access, 2 таблицы - первая содержит данные о предпринимателях (9 полей), вторая - данные об их торговых точках(10...

Access в delphi, c запросами
Привет))) нужно сделать бд в акцесе, привязать его к делфи, создать запросы и по этим запросам в отчет))))) Заранее спасибо)) Договорная...

Перенос файла с запросами на PQ в access
Доброго времени суток! Имеется достаточно большой с большим количеством запросов файл на power query. Поставили задачу вмонтировать...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru