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

Работа с БД в Access

03.12.2014, 20:57. Показов 2462. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть задача:
Кликните здесь для просмотра всего текста

Таблица Coordinates базы данных содержит координаты отрезка x1, x2 на координатной оси.
1 Используя SQL запрос, сформировать список вида (len; num), где len – длина отрезка, округлённая до целого числа, num – количество отрезков длины len. Список отсортировать по возрастанию поля len.
2 Сохранить получившийся список в таблицу Frequencies, предварительно очистив её содержимое.
3 Используя SQL запрос, найти записи в Frequencies, в которых len больше num.

Пример таблицы Coordinates: Вывод:
0 1 1;2
2,5 0 3;1
-3,145 -2

Замечания
– Пункты 1 и 2 выполнить в разных циклах. В результате выполнения пункта 1 должна быть создана коллекция. В следующем цикле эту коллекцию выгрузить в таблицу Frequencies.

– Использовать СУБД Access. Для этого предварительно нужно создать базу данных с таблицами Coordinates и Frequencies. В таблицу Coordinates нужно занести координаты нескольких отрезков.

В программе нужно правильно перехватывать возможные исключения.

– Все ресурсы, необходимые для установки соединения и выполнения запросов, должны быть возвращены в секции finally в обратном порядке.

Обработка, группировка и сортировка значений таблицы Coordinates должны быть выполнены SQL-запросом.
Нужны 4 запроса.
1. Выборка записей вместе с обработкой, группировкой, сортировкой
SELECT ... AS len, Count(*) AS num FROM Coordinates GROUP BY ... ORDER BY ...
2. Удаление всех записей из таблицы Frequencies.
3. Добавление записи в таблицу Frequencies.
4. Выборка записей из таблицы Frequencies.
– Правильное округление в SQL int(аргумент + 0.5).


Что-то я вообще не вкуриваю. Как я понял, сначала нужно подключиться к БД, потом получить данные, обработать их и результат поместить в коллекцию, далее после прочтения всех данных и заполнения коллекции её содержимое перекинуть во вторую таблицу и отсортировать. С подсчётом длины и количества отрезков определённой длины я разобрался. А вот как считывать данные? Мне надо считать всю строку и разбить её на две переменные? Или как? Обратно ж можно из коллекции во вторую таблицу построчно закидывать. И что делать с округлением?

Добавлено через 5 часов 5 минут
Вот частичный код программы. При попытке вставки выдаётся ошибка формата. Где косяк?
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.OleDb;
using System.Data;
 
 
namespace Task1
{
    class Program
    {
        const string connectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=""E:\segmentbd.mdb""";
        static void Main(string[] args)
        {
            Dictionary<double, int> lenDict = new Dictionary<double, int>();
            OleDbConnection cnn = new OleDbConnection(connectionString);
            cnn.Open();
            OleDbCommand odb = cnn.CreateCommand();
            odb.CommandText = "Select * From Coordinates";
            //odb.CommandText = "SELECT ROUND int(ABS(x1 - x2)+0.5) as len, Count(*) as num FROM coordinates GROUP BY len ORDER BY len";
            using (OleDbDataReader dr = odb.ExecuteReader())
            { 
            while (dr.Read())
            {
               
                double x1=Double.Parse(dr["x1"].ToString());
                double x2 = Double.Parse(dr["x2"].ToString()); 
                double len = Math.Abs(x1-x2);
                try
                {
                    lenDict.Add(len, 1);
                }
                catch (ArgumentException)
                {
                    lenDict[len]++;
                }
                //Console.WriteLine("{0}", len);
            }
            }
            foreach (KeyValuePair<double, int> kvp in lenDict)
            {
                Console.WriteLine("Key = {0}, Value = {1}",
                    kvp.Key, kvp.Value);
            }
            
            odb.CommandText = "Delete From Frequencies";
            try
            {
                odb.ExecuteNonQuery();
            }
            catch (OleDbException ex)
            {
                Exception error = new Exception("Sorry! That car is on order!", ex);
                throw error;
            }
            //odb.CommandText = "SELECT ROUND(len+0.5) as len, Count(*) as num FROM coordinates GROUP BY len ORDER BY len";
            foreach (KeyValuePair<double, int> kvp in lenDict)
            {
                string sql = string.Format("Insert Into Frequencies (len, num) Values ({0}, {1})", Double.Parse(lenDict.Keys.ToString()), Int32.Parse(lenDict.Values.ToString()));
                using (OleDbCommand cmd = new OleDbCommand(sql, cnn))
                {
                    cmd.ExecuteNonQuery();
                }
            }
            cnn.Close();
            Console.ReadKey();
        }
    }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.12.2014, 20:57
Ответы с готовыми решениями:

Что лучше: работа с Access через ADO.NET или силами самого Access?
Считаю, что лучше работать с регулярно поступающим в Access объемом данных, разработав приложение Windows Forms C# и управляя процессом...

Возможна ли работа проги на Access без Access?
Не подскажете возможна ли работа проги на Access без установленного на машине Access? Т.е. самостоятельная работа проги через какой-нибудь...

Работа с БД Access без Access
Добрый день, форумчане! Уже больше месяца я заполняю БД собственного сочинения с необходимой информацией по поставщикам (адреса,...

1
6 / 6 / 2
Регистрация: 31.03.2013
Сообщений: 120
05.12.2014, 00:03  [ТС]
Вот текст программы... Можно её как-то улучшить. И почему-то не работает сортировка. Помогите разобраться
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.OleDb;
using System.Data;
 
 
namespace Task1
{
    class Program
    {
        const string connectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=""E:\segmentbd.mdb""";
        static void Main(string[] args)
        {
            Dictionary<double, int> lenDict = new Dictionary<double, int>();
            OleDbConnection cnn = new OleDbConnection(connectionString);
            cnn.Open();
            OleDbCommand odb = cnn.CreateCommand();
           // odb.CommandText = "Select SELECT ROUND(x1,1) From Coordinates";
           // odb.CommandText = "Select Round ((x1),-1) as x1, Round ((x2),-1) as x2 From Coordinates";
            odb.CommandText = "Select int((x1)+0.5) as x1, int((x2)+0.5) as x2 From Coordinates";
            using (OleDbDataReader dr = odb.ExecuteReader())
            { 
            while (dr.Read())
            {
               
                int x1=Int32.Parse(dr["x1"].ToString());
                int x2 = Int32.Parse(dr["x2"].ToString());
                //double x2 = Double.Parse(dr["x2"].ToString()); 
                double len = Math.Abs(x1-x2);
                try
                {
                    lenDict.Add(len, 1);
                }
                catch (ArgumentException)
                {
                    lenDict[len]++;
                }
                //Console.WriteLine("{0}", len);
            }
            }
            foreach (KeyValuePair<double, int> kvp in lenDict)
            {
                Console.WriteLine("Key = {0}, Value = {1}",
                    kvp.Key, kvp.Value);
            }
            
            odb.CommandText = "Delete From Frequencies";
            try
            {
                odb.ExecuteNonQuery();
            }
            catch (OleDbException ex)
            {
                Exception error = new Exception("Sorry! That car is on order!", ex);
                throw error;
            }
            //odb.CommandText = "SELECT ROUND(len+0.5) as len, Count(*) as num FROM coordinates GROUP BY len ORDER BY len";
            foreach (KeyValuePair<double, int> kvp in lenDict)
            {
                double a = Double.Parse(kvp.Key.ToString());
 
 
              int b = Int32.Parse(kvp.Value.ToString()); 
                string sql = string.Format("Insert Into Frequencies (len, num) Values ('{0}', '{1}')",a, b);
                using (OleDbCommand cmd = new OleDbCommand(sql, cnn))
                {
                    cmd.ExecuteNonQuery();
                }
            }
            OleDbCommand sss = cnn.CreateCommand();
            sss.CommandText = "SELECT len From Frequencies Group by len Order by len asc";
           // using (OleDbDataReader da = sss.ExecuteReader())
            //{
                sss.ExecuteNonQuery();
           // }
            cnn.Close();
            Console.ReadKey();
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.12.2014, 00:03
Помогаю со студенческими работами здесь

работа в ms access
нужно описать базу данных,запросы в access и на языке sql

работа с БД в Access
Здравствуйте, уважаемые форумчане и программисты! Подскажите, пожалуйста, как создавать запрос на создание резервной копии таблицы в MS...

Работа с Access БД
Подскажите для того, что бы прочитать структуру БД: -Типы полей -Узнать ключи -Узнать какие таблицы есть и т п Нужно ли прибегать...

Работа с ACCESS
Здравствуйте, подскажите как через WinAPI подключить Acess, т.е. как вывести значение из определённой ячейки в EDIT? (Если можно...

Работа с БД MS Access
Задание: 1. Создать БД с одной таблицей. 2. Подключиться к ней из консольного приложения. 3. Из приложения добавить, изменить, удалить...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru