Форум программистов, компьютерный форум, киберфорум
Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/25: Рейтинг темы: голосов - 25, средняя оценка - 4.56
1 / 1 / 1
Регистрация: 24.08.2010
Сообщений: 44

SQL запрос в форме кросс-таблицы

02.02.2011, 13:59. Показов 4753. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Делаю базу данных в Delphi с помощью ado. Прошу помощи вот с таким запросом в SQL. Есть определенные столбцы(в скобках-их значения): Фио, место выдачи (москва, самара..), соц.статус (учащийся, работающий, выпускник..) Они не содержат чисел. А мне нужно узнать сколько (например) студентов(это социальный статус его) в городе 1, в городе 2..; сколько работающих(это социальный статус его) в городе 1, в городе 2. Вот скрин кусочка базы и таблицы готовой в Excel (для примера)

Изначально начинал вот так -
SQL
1
2
SELECT COUNT(Fam2), MESTO7, SOZ8 FROM ':1Samara23:All.dbf' GROUP BY MESTO7,SOZ8;
SELECT COUNT(поле_фамилия),поле_место_жительства, поле_социальный статус FROM ':1Samara23:All.dbf' GROUP BY поле_место_жительства, социальный статус;
Получалось не совсем то..
Мне посоветовали изменить запрос
SQL
1
2
SELECT place, (SELECT COUNT(t1.b)  FROM t t1 WHERE t1.b='студент' AND t1.place=t.place) "студент", 
(SELECT COUNT(t1.b)  FROM t t1 WHERE t1.b='работающий' AND t1.place=t.place) "работающий" FROM t GROUP BY place;
Практически получилось, у меня заработало вот-
SQL
1
2
SELECT MESTO7, (SELECT COUNT(t1.SOZ8) FROM 2009 t1 WHERE t1.SOZ8='Студент'),  
(SELECT COUNT(t1.SOZ8)  FROM 2009 t1 WHERE t1.SOZ8='Работающий') FROM 2009 GROUP BY MESTO7;
Не понимаю куда вот это деть, хотя это по сути самое главное
SQL
1
AND t1.place=t.place) "студент",
Прошу помочь!
Миниатюры
SQL запрос в форме кросс-таблицы  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.02.2011, 13:59
Ответы с готовыми решениями:

SQL запрос на создание таблицы !
Подскажите вот начал делать таблицу и нужно, что бы в таблице Заказчик ID firm был FK связанный с PK таблицы Справочник фирм ! create...

SQL запрос для заполнения таблицы
Помогите пожалуйста кто сможет. Как написать SQL запрос для заполнения таблицы. Я таблицу создал и начал заполнять не используя запроса(((,...

Как связать таблицы через sql запрос
Добрый день, имеется, к примеру, такие таблицы со связью: https://habrastorage.org/files/afd/75a/67d/afd75a67da9347dab86bf5051b3d4975.png...

3
 Аватар для arni
914 / 879 / 62
Регистрация: 06.01.2010
Сообщений: 2,367
Записей в блоге: 6
02.02.2011, 15:46
может так:
SQL
1
2
3
4
5
SELECT t.MESTO7, 
       (SELECT COUNT(t1.SOZ8) FROM 2009 t1 WHERE t1.SOZ8='Студент' AND t1.place=t.place) "Студент",  
       (SELECT COUNT(t1.SOZ8) FROM 2009 t1 WHERE t1.SOZ8='Работающий' AND t1.place=t.place) "Работающий" 
  FROM 2009 t
 GROUP BY t.MESTO7;
1
1 / 1 / 1
Регистрация: 24.08.2010
Сообщений: 44
02.02.2011, 15:52  [ТС]
Цитата Сообщение от arni Посмотреть сообщение
может так:
SQL
1
2
3
4
5
SELECT t.MESTO7, 
       (SELECT COUNT(t1.SOZ8) FROM 2009 t1 WHERE t1.SOZ8='Студент' AND t1.place=t.place) "Студент",  
       (SELECT COUNT(t1.SOZ8) FROM 2009 t1 WHERE t1.SOZ8='Работающий' AND t1.place=t.place) "Работающий" 
  FROM 2009 t
 GROUP BY t.MESTO7;
Спасибо Вам огромное за помощь! Именно так! Неделю на это потратил...
Только если не убрать из выражения
SQL
1
t1.place=t.place) "Студент",
"Студент" то не работает. А можно как то эти столбцы назвать, или почему не работает?
0
 Аватар для arni
914 / 879 / 62
Регистрация: 06.01.2010
Сообщений: 2,367
Записей в блоге: 6
02.02.2011, 16:10
SQL
1
2
3
4
5
SELECT t.MESTO7, 
       (SELECT COUNT(t1.SOZ8) FROM 2009 t1 WHERE t1.SOZ8='Студент' AND t1.place=t.place) STUDENT,  
       (SELECT COUNT(t1.SOZ8) FROM 2009 t1 WHERE t1.SOZ8='Работающий' AND t1.place=t.place) WORKER 
  FROM 2009 t
 GROUP BY t.MESTO7;
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.02.2011, 16:10
Помогаю со студенческими работами здесь

Фильтровать значения по полю из кросс-таблицы
Здравствуйте, на картинке схема табличек Сейчас у меня запрос с фильтром по одному полю из Tasks: SELECT * FROM Tasks WHERE UsId =...

SQL запрос внутри таблицы с унарной связью
Всем привет, предположим у нас есть таблица Преподаватели. Как видите тут есть унарная связь по столбцам "номер_преподавателя" и...

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

SQL запрос: вывести имя таблицы с максимальным количеством полей
Вывести имя таблицы с макс.кол-вом полей

SQL запрос в кнопку на форме
Друзья столкнулся с проблемой, я решил сделать так чтобы при нажатии на кнопку в форме ACCESS выполнялся sql запрос на добавление, ...


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

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