Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
2 / 2 / 0
Регистрация: 07.03.2014
Сообщений: 47
MS Access

Не работает Count()

28.05.2016, 20:48. Показов 3351. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Определяя длину отрезка мы выводим ее в дополнительном столбце. Следующий столбец должен показывать сколько отрезков с такой длинной.
Count работает только с теми вариантами где идентичны координаты, со значениями которые вычисляются в запросе(длиной) уже не работает.
Где не правильно?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.OleDb;
using System.Data;
using System.Data.SqlClient;
 
namespace Database
{
    class Program
    {
        static void Main(string[] args)
        {
            string connStr = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=""\..\StudeBD.mdb""";
            OleDbConnection conn = new OleDbConnection(connStr);
            try
            {
                conn.Open();
            }
            catch (OleDbException se)
            {
                Console.WriteLine("Ошибка подключения:{0}", se.Message);
                return;
            }
            finally
            {
                OleDbCommand cmdView = new OleDbCommand("Select x1, x2, int(x2-x1+0.5) AS len, Count (len) AS num  FROM StudeDatabase GROUP BY x1, x2;", conn);
                using (OleDbDataReader dr = cmdView.ExecuteReader(CommandBehavior.CloseConnection))
                {
                    while (dr.Read())
                    {
                        Console.WriteLine("{0}\t{1}\t{2}\t{3}", dr.GetValue(0).ToString().Trim(), dr.GetValue(1).ToString().Trim(), dr.GetValue(2).ToString().Trim(), dr.GetValue(3).ToString().Trim());
                    }
                }
            }
            conn.Close();
            conn.Dispose();
            Console.WriteLine();
            Console.ReadKey();
        }
    }
}
При запросе без округления: "Select x1, x2, (x2-x1) AS len, Count (len) AS num FROM StudeDatabase GROUP BY x1, x2;" результат count тот же:


-3,145 | -2 | 1,145 | 1
-2,5 | -5 | -2,5 | 1
0,0000 | 1 | 1 | 1
2,5 | 0,0000 |-2,5 | 2
5 | 2,5 | -2,5 | 1
5,1 | 2,6 | -2,5 | 2
Вот тестовая база данных:

StudeBD.zip
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.05.2016, 20:48
Ответы с готовыми решениями:

Не работает программа: The count of column names and source expressions do not match
Добрый день. Программа выдает такую ошибку, не подскажите как исправить?

Нюансы синтаксиса: statement for - как понимать запись for (count=0, mask=1; count != 16; count++, mask<<= 1)?
Много всяких языков попадалось, относительно много конечно, но такое вижу первый раз, что бы тело FOR имело не 3 оператора - начальный,...

COUNT не работает
Выводит 0, вместо положенной 3. Не могу никак понять, что не так. $result=mysql_query(&quot;SELECT COUNT(*) FROM messages WHERE...

6
2 / 2 / 0
Регистрация: 07.03.2014
Сообщений: 47
29.05.2016, 12:33  [ТС]
Может дело в группировке? Как организовавывается подзапрос в таком случае? Хотя бы подскажите является ли именованное поле(такое как len) полноправным полем(можно ли его использовать не только в GROUP и ORDER). В общем буду блаодарен хоть за какие то мысли.
0
1167 / 885 / 517
Регистрация: 09.04.2014
Сообщений: 2,098
29.05.2016, 19:47
Лучший ответ Сообщение было отмечено Herasima как решение

Решение

Цитата Сообщение от Herasima Посмотреть сообщение
Может дело в группировке?
Count выдает количество строк в группе

T-SQL
1
Select (x2-x1) AS len, Count (len) AS num FROM StudeDatabase GROUP BY (x2-x1)
Добавлено через 6 минут
если вам зачем-то нужны координаты отрезков, то
T-SQL
1
2
3
4
5
6
Select distinct x1, x2, t.len, t.num
 FROM StudeDatabase sd
 join 
  (
    Select (x2-x1) AS len, Count (len) AS num FROM StudeDatabase GROUP BY (x2-x1)
  ) t on t.len=(sd.x2-sd.x1)
1
2 / 2 / 0
Регистрация: 07.03.2014
Сообщений: 47
29.05.2016, 19:57  [ТС]
Спасибо, это то что нужно, но если не сложно объясните как сделать так что б выводилось и значение координат и длинна и количество идентичных отрезков(x1, x2, len, num). Такое как
T-SQL
1
Select x1, x2, int(x2-x1 + 0.5) AS Len, COUNT(len) AS Num FROM StudeDatabase GROUP BY x1, x2, (x2-x1);
не работает.
Как это сделать в одном запросе?
Хочется разобраться как работает.
0
1167 / 885 / 517
Регистрация: 09.04.2014
Сообщений: 2,098
29.05.2016, 20:29
Цитата Сообщение от Herasima Посмотреть сообщение
Как это сделать в одном запросе?
если идентичные отрезки, это имеющиие одиноковую длинну, то 2 запрос в моем посте это то что вам нужно
0
2 / 2 / 0
Регистрация: 07.03.2014
Сообщений: 47
29.05.2016, 21:52  [ТС]
ВЫ проверяли запрос?
T-SQL
1
2
3
4
5
6
Select distinct x1, x2, t.len, t.num
 FROM StudeDatabase sd
 join 
  (
    Select (x2-x1) AS len, Count (len) AS num FROM StudeDatabase GROUP BY (x2-x1)
  ) t on t.len=(sd.x2-sd.x1)
У меня пишет: Ошибка синтаксиса в предложении FROM
0
1167 / 885 / 517
Регистрация: 09.04.2014
Сообщений: 2,098
30.05.2016, 00:13
Может так
T-SQL
1
2
3
4
5
6
Select distinct x1, x2, t.len, t.num
 FROM StudeDatabase sd
INNER JOIN
  (
    Select (x2-x1) AS [len], Count (*) AS num FROM StudeDatabase GROUP BY (x2-x1)
  ) t on t.len=(sd.x2-sd.x1)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.05.2016, 00:13
Помогаю со студенческими работами здесь

ORDER BY COUNT не работает
Добрый день! Нужна помощь - упорно не хочет обрабатываться запрос: SELECT notes.id, notes.title FROM comment, notes WHERE...

Запрос Select COUNT(*) не работает
Суть вот в чем: Я программирую на Делфи 7, сама база в Access. Я написала запрос, который должен подсчитывать количество договоров по 2м...

SELECT count (DISTINCT ...) не работает !!!
Блин, Access - хромая утка! Запрос вида SELECT Count (DISTINCT CustomerID), OrderDate from BigBaza GROUP BY OrderDate ORDER...

Ошибка MySQL error: Column count doesn't match value count at row 1
Подскажите, пожалуйста где тут ошибка? Вылазит ошибка: MySQL error: Column count doesn't match value count at row 1 INSERT INTO...

Ошибка в запросе: Column count doesn't match value count at row 1
Здравствуйте, я новичок в изучении php и sql. При добавлении новой книги в БД необходимо выбрать предмет из выпадающего списка. Когда...


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

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