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

Запрос в базу данных по просчету количества месяцев

03.06.2017, 16:31. Показов 514. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно запросом посчитать месяца (`d`) где SUM(count_100)!=0, подскажите как друзья
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.06.2017, 16:31
Ответы с готовыми решениями:

Функции вычисления количества дней заданного месяца и количества месяцев между двумя датами
Область first - положительное целое число , год; second - положительное целое число от 1 до 12 - номер месяца. Реализовать методы daysCount...

Вставка в базу данных с интервалом времени и количества
импортируется Excel файл в БД, при количестве строк меньше или равно 300 все происходит нормально. Как только приходит на вход файл в...

Запрос на добавление данных в базу данных из формы. Mysql
Надо, чтобы данные вводились из формы. Я пишу так, но не знаю как дописать. <html><head> ...

11
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
03.06.2017, 18:34
SQL
1
SELECT d FROM `table_name` WHERE SUM(count_100)!=0 GROUP BY d
0
20 / 20 / 9
Регистрация: 25.11.2016
Сообщений: 105
03.06.2017, 18:40
что такое `d` и count_100 ?
0
0 / 0 / 0
Регистрация: 05.10.2016
Сообщений: 20
03.06.2017, 18:50  [ТС]
d - столб с датами, count_100 - столб с числами
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
03.06.2017, 18:57
В поле d можно хранить дату в виде "201706", чтобы работала группировка по месяцам
0
0 / 0 / 0
Регистрация: 05.10.2016
Сообщений: 20
03.06.2017, 18:59  [ТС]
Цитата Сообщение от plohoyav Посмотреть сообщение
В поле d можно хранить дату в виде "201706", чтобы работала группировка по месяцам
мне нужно посчитать месяца, где SUM(count_100)!=0; именно получить число
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
03.06.2017, 19:06
Если объём БД маленький можно конвертировать дату приводя к виду "201706".
Если большой - добавить второе поле с датой вида "годмесяц"

Добавлено через 1 минуту
Некоторые хранят дату в виде поля TIMESTAMP, некоторые в виде INTEGER метки времени юникс, или используют другой формат.

Добавлено через 4 минуты
Отдельно для каждого значения d вычисляется сумма count_100 и если она не равна нулю,
выводится d

SQL
1
SELECT DISTINCT(d) FROM `table_name` WHERE SUM(count_100)!=0 GROUP BY d
Общее кол-во строк в результате

SQL
1
SELECT COUNT(*) FROM (SELECT DISTINCT(d) FROM `table_name` WHERE SUM(count_100)!=0 GROUP BY d)
0
0 / 0 / 0
Регистрация: 05.10.2016
Сообщений: 20
03.06.2017, 19:22  [ТС]
спасибо огромное

SQL
1
SELECT COUNT(*) FROM (SELECT DISTINCT(d) FROM `table_name` WHERE SUM(count_100)!=0 GROUP BY d)
как правильно обработать этот запрос?
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
03.06.2017, 19:36
Сначала в phpmyadmin выполнить, проверить результат

Для работы с БД можно взять [РЕЦЕПТ] Класс для работы с БД

PHP
1
echo $x = mf('SELECT COUNT(*) as x FROM (SELECT DISTINCT(d) FROM `table_name` WHERE SUM(count_100)!=0 GROUP BY d)', 'x');
0
0 / 0 / 0
Регистрация: 05.10.2016
Сообщений: 20
03.06.2017, 20:20  [ТС]
PHP
1
2
3
$x = mysqli_query($connection,'SELECT COUNT(*) as x FROM (SELECT DISTINCT(d) FROM `application` WHERE SUM(count_100)!=0 GROUP BY d)', 'x');
$row = mysqli_fetch_row($x);
$count_m = $row[0];
я делаю так у меня не получается
0
313 / 312 / 221
Регистрация: 11.07.2015
Сообщений: 1,107
03.06.2017, 23:11
Извините, ошибка. SUM в WHERE использовать нельзя, можно в HAVING

PHP
1
2
3
$x = mysqli_query('SELECT COUNT(*) as y FROM (SELECT d, SUM(count_100) x FROM `application` GROUP BY d HAVING x!=0) t');
$row = mysqli_fetch_row($x);
$count_m = $row[0];
Добавлено через 56 минут
Проверьте правильность алгоритма:

1. Берутся все строки из таблицы application
2. Делятся на группы с одинаковым значением поля d
3. В каждой группе вычисляется сумма полей count_100 и сохраняется в переменную x
4. Выбираются группы, в которых x не равно нулю, вычисляется число групп
0
0 / 0 / 0
Регистрация: 05.10.2016
Сообщений: 20
04.06.2017, 00:18  [ТС]
получается 16 а на деле 3

Добавлено через 7 минут
PHP
1
2
3
$x = mysqli_query ($connection, 'SELECT COUNT(*) as y FROM (SELECT MONTH(`d`), SUM(count_100) x FROM `application` GROUP BY MONTH(`d`) HAVING x!=0) t');
$row = mysqli_fetch_row($x);
$count_m = $row[0];
вот так правильно
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.06.2017, 00:18
Помогаю со студенческими работами здесь

Запрос в базу данных
Доброго времени суток вам ! у меня возникла такая проблема после подключения бд к скрипту на главной странице выходит вот это INSERT...

Запрос в базу данных
Здравствуйте, объясните мне, правильно ли я делаю запрос? &НаСервере Функция КонтактноеЛицоПриИзмененииНаСервере() ...

Запрос в базу данных
Добрый день ещё раз. Интересуют несколько вопросов)) 1) Как можно вынести строку подключения к базе данных MSSQL в конфигурационный...

QT. Запрос в базу данных
Приветствую. Необходимо сделать запрос на выборку из БД. По идее вот так должно работать. Делал подобное в другом проекте int...

Запрос в базу данных
Всем доброго дня! Помогите пожалуйста найти ошибку в запросе на изменение данных, уже мозги кипят, буду очень благодарен. <?php ...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
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
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru