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

Подсчёт строк в таблице по условию

03.10.2012, 14:15. Показов 3960. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужна помощь...
У меня есть таблица :
ID | ParentID | Name |
----------------------
1 | 0 | User1 |
2 | 1 | User2 |
3 | 1 | User3 |
4 | 1 | User4 |
5 | 2 | User5 |
6 | 2 | User6 |
7 | 3 | User7 |
8 | 1 | User8 |
9 | 2 | User9 |
10 | 3 | User10 |

Необходимо в ACCESS'е сделать запрос возвращающий количество записей, у которых в столбце [ParentID] содержится значение равное значению из столбца [ID]. на выходе должно получиться:

ID | CountID |
--------------
1 | 4 |
2 | 3 |
3 | 2 |
4 | 0 |
5 | 0 |
6 | 0 |
7 | 0 |
8 | 0 |
9 | 0 |
10 | 0 |

Ломаю голову уже вторые сутки...
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.10.2012, 14:15
Ответы с готовыми решениями:

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

Подсчет уникальных чисел в таблице по заданному условию
Друзья, всем привет. Помогите с решением задачки. Застопорился на одной из формул. В общем есть некая база, в которой необходимо...

Нужен подсчет строк по каждому договору в первой и второй таблице.Количесьво строк может меняться
И снова здраствуйте. Помогите пожадуйста с двумя вопросами. 1 нужен подсчет строк по каждому договору в первой и второй таблице.Количесьво...

13
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
03.10.2012, 15:34
alexnike, попробуйте такой запрос
SQL
1
2
3
SELECT a1.id, nz(-SUM(a2.parentid=a1.id),0) AS dd
FROM МояТаблица AS a1 LEFT JOIN МояТаблица AS a2 ON a1.id=a2.parentid
GROUP BY a1.id
1
0 / 0 / 0
Регистрация: 03.10.2012
Сообщений: 10
03.10.2012, 15:46  [ТС]
Спасибо за пример...
Я не силён в SQL поэтому появились вопросы
"a1" , "a2" , "dd" - это "абстрактные" имена таблиц или что?
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
03.10.2012, 15:49
alexnike, вы знаете, при написании даже простейшей субд слова - "а я не силен в SQL" вызывают недоумение... без оного языка вам вообще лучше это дело забросить...

ну и по теме: это все псевдонимы(alias) таблиц и полей...
1
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
03.10.2012, 15:52
Цитата Сообщение от alexnike Посмотреть сообщение
Спасибо за пример...
Я не силён в SQL поэтому появились вопросы
"a1" , "a2" , "dd" - это "абстрактные" имена таблиц или что?
Это алиасы (псевдонимы) имен. Поскольку в запросе дважды участвует одна и та же таблица, то надо как-то их узнавать. Вот поэтому каждому из экземпляров присвоен свой уникальный алиас.
1
0 / 0 / 0
Регистрация: 03.10.2012
Сообщений: 10
03.10.2012, 16:13  [ТС]
Спасибо за разъяснения...
БД не я создавал. Мне надо написать ещё одну функцию в приложении на Pascal. Теперь надо будет про SQL много почитать...
А запрос я под "себя" попробую переделать... Если не получится ... буду мучать вопросами...

Добавлено через 15 минут
Цитата Сообщение от mobile Посмотреть сообщение
alexnike, попробуйте такой запрос
SQL
1
2
3
SELECT a1.id, nz(-SUM(a2.parentid=a1.id),0) AS dd
FROM МояТаблица AS a1 LEFT JOIN МояТаблица AS a2 ON a1.id=a2.parentid
GROUP BY a1.id
Разве в данном случае используется "Sum" или всё таки "Count"?
Ведь мне надо увидеть количество записей...
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
03.10.2012, 16:24
Цитата Сообщение от alexnike Посмотреть сообщение
Разве в данном случае используется "Sum" или всё таки "Count"?
Ведь мне надо увидеть количество записей...
Вы не обратили внимания на аргумент функции Sum. Он логический, в нем равенство двух полей. Если значения полей равны будет True, не равны False. True в акцессе равно -1, False=0. Сумма нулей это 0, а сумма минус единиц как раз равна количеству случаев совпадения полей, только со знаком минус.

Ну и последнее - в выражении используется функция NZ, превращающая NULL-значения в значения аргумента по умолчанию, в данном случае это 0. Это для того, чтобы в запросе не было пустых полей parentid, а были нули. Т.е. точно по вашему ТЗ.
0
0 / 0 / 0
Регистрация: 03.10.2012
Сообщений: 10
03.10.2012, 16:24  [ТС]
Попробовал сделать этот запрос в ACCESS в режиме SQL

SELECT a1.id, nz(-Sum(a2.parentid=a1.id),0) AS dd
FROM Users AS a1, Users AS a2 ON a1.id=a2.parentid
GROUP BY a1.id;

ACCESS выругался на выражение FROM

изменил его
FROM Users AS a1, Users AS a2

ACCESS запросил значение выражения a1.id я указал "1"+[Enter].... ACCESS завис...
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
03.10.2012, 16:30
alexnike, вы изменили запрос и он стал ошибочным в синтаксисе. Использование ON во From возможно только при наличии отношения - Inner/Left/Right Join, которое в вашем варианте отсутствует.
А почему вы не захотели использовать выражение, которое я написал ранее?
0
0 / 0 / 0
Регистрация: 03.10.2012
Сообщений: 10
03.10.2012, 17:18  [ТС]
Первоначальная конструкция запроса при вставке в Access преобразуется в непонятно что... Возможно это из за того что Access старый (MSO2003)... И в конце концов выдаёт одну запись "Количество совпадений вообще", а мне необходимо получить на выходе таблицу совпадений значений первого столбца во втором.
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
03.10.2012, 17:48
Цитата Сообщение от alexnike Посмотреть сообщение
Первоначальная конструкция запроса при вставке в Access преобразуется в непонятно что... Возможно это из за того что Access старый (MSO2003)... И в конце концов выдаёт одну запись "Количество совпадений вообще", а мне необходимо получить на выходе таблицу совпадений значений первого столбца во втором.
Посмотрите пример по вашему ТЗ
Вложения
Тип файла: rar Alexnike.rar (14.7 Кб, 33 просмотров)
1
0 / 0 / 0
Регистрация: 03.10.2012
Сообщений: 10
05.10.2012, 17:42  [ТС]
К сожалению скачать архив не получается... (почемуто скачивается PHP-файл). Нельзя ли его переслать на мой адрес (alexnike@inbox.ru)
А вообще для решения данной задачи в установленный срок я воспользовался "услугами" Delphi7.
Задал цикл в котором поочерёдно проверял каждую запись.
Правда скорость обработки данных (в таблице ~6500 записей) оставляет желать лучшего.
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
05.10.2012, 18:55
alexnike, отправил по почте
1
0 / 0 / 0
Регистрация: 03.10.2012
Сообщений: 10
07.10.2012, 22:20  [ТС]
Спасибо за помощь. Пример работает отлично. Не много доработал (подогнал под свою задачу).
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.10.2012, 22:20
Помогаю со студенческими работами здесь

DataGridView - подсчёт строк по условию
Как правильно будет посчитать кол-во строк по условию. Например есть столбец, в столбце данные, и уже с этими данными работать. Картинку...

Подсчет строк в таблице
Есть БД, в ней есть таблица. Нужно подсчитать количество строк таблицы и вписать в переменную, возможно ли это?

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

Подсчет количества строк по условию и запись в таблицу
Добрый день Уважаемые знатоки. Прошу помощи знающих людей. Сам новичок. Есть БД. В ней таблицы Предприятия, Техника и т.д. Есть форма -...

Подсчет количества строк в ленточной форме по условию
Добрый день. Вопрос вроде простой но неполучается.(на форуме ответа не нашел) Из предидущей формы исходя из выбранных условий формирую...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru