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

Работа с БД в Access

03.12.2014, 20:57. Просмотров 1893. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.12.2014, 20:57
Ответы с готовыми решениями:

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

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

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

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

1
6 / 6 / 2
Регистрация: 31.03.2013
Сообщений: 120
05.12.2014, 00:03  [ТС] 2
Вот текст программы... Можно её как-то улучшить. И почему-то не работает сортировка. Помогите разобраться
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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
05.12.2014, 00:03

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

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

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

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

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

Работа с Access
Доброго времени суток, тут такой вопрос, как в таблице (мастер подстановок), отразить не ид а...

Работа в Access
Всем привет. Увлекаюсь «Аксом». Делал 2 проекта для разных контор, причём во второй до сих пор...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.