Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
1agaka1
25 / 25 / 35
Регистрация: 21.10.2013
Сообщений: 79
#1

Добавление введенных данных к существующей БД и возвращение содержимого базы, отсортированного по датам рождения - C++

16.02.2014, 19:21. Просмотров 267. Ответов 1
Метки нет (Все метки)

Данные о студентах в виде «Фамилия, имя, группа, да-та рождения, средний рей-тинг»
Добавление введенных данных к существующей БД и возвращение содержимого базы, отсортированно-го по датам рождения
ПОМОГИТЕ пожалййста
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.02.2014, 19:21
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Добавление введенных данных к существующей БД и возвращение содержимого базы, отсортированного по датам рождения (C++):

База данных по датам рождения - Pascal ABC
Program book; uses Crt; Type fam=record ff: string; {фамилия} year: string; {год рождения} month: 1..12; {месяц рождения} day:...

Выборка данных из базы по датам! - PHP БД
Подскажите как решить задачу! Есть таблица базы данных: Вывел сумму колонки "sum": $orders_sum = 0; foreach($orders as $key...

Обновление существующей базы данных - C#
Пытаюсь обносить базу данных, включил миграции(Enable-Migrations), добавил миграции (Add-migrations), пытаюсь обновить базу...

Создание новой базы данных по существующей - FoxPro
Здравствуйте. Не подскажите, как из базы данных (содержащую одну колонку) построить новую базу данных с 3 колонками, получив её из...

Создание запроса для существующей базы данных - MS Access
Есть существующая база данных (база библиотечных книг). Требуется создать запрос на вывод списка популярных книг. т.е. 1 по...

Добавление новых значений к существующей базе данных - C# MVC
Собственно вопрос в названии темы. Немного непонятно как происходит добавление значений в таблицу. Попробовал через встроенный конструктор...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
GuGo1991
267 / 261 / 93
Регистрация: 02.08.2012
Сообщений: 609
16.02.2014, 23:28 #2
1agaka1, БД как текстовик сойдёт?

Кликните здесь для просмотра всего текста
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
#include <iostream>
#include <windows.h>
#include <fstream>
 
char getChoice(char choice);
void whatToDo(char choice);
int countS(std::istream& f, int& i);
 
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    char myChoice;
    
    myChoice = getChoice(myChoice);
    
    while(myChoice != '3')
    {
        switch(myChoice)
        {
            case '1':
                whatToDo(myChoice);
                break;
            case '2':
                whatToDo(myChoice);
                break;
        }
        myChoice = getChoice(myChoice);
    }
    
    system("pause");
    return 0;
}
 
int countS(std::istream& f, int& i) //Функция счёта строк
{
    char cur = '\0';
    while(f.get(cur))
    {
        if(cur == '\n')
            i++;
    }
    return i;
}
 
char getChoice(char choice) //Функция выбора опции
{
    std::cout << "\nВыберите опцию\n" <<
                 "1 - добавить студента\n" <<
                 "2 - вывести список студентов\n" <<
                 "3 - выйти из программы\n" <<
                 "Ваш выбор: ";
    std::cin >> choice;
    while(choice != '1' &&
          choice != '2' &&
          choice != '3')
    {
        std::cout << "Нет такой опции. Повторите выбор.\n"
                     "Ваш выбор: " << choice;
    }
    return choice;
}
 
void whatToDo(char choice) //Функция выполнения опции
{
    std::string sName, fName, id,
                sN, fN, ID;
    float aScore;
    int year, month, day, quant, index = 0, y, m, d;
    char cur;
    if(choice == '1') //Добавление студента
    {
        std::ofstream addStudent("data.txt", std::ios::app);
        std::cout << "Сколько студентов добавить? "; std::cin >> quant;
        for(int i = 0; i < quant; i++)
        {
            std::cout << "\nФамилия: "; std::cin >> sName;
            std::cout << "Имя: "; std::cin >> fName;
            std::cout << "Группа: "; std::cin >> id;
            std::cout << "Дата рождения\nГод: "; std::cin >> year;
            while(year < 1950 || year > 1999)
            {
                std::cout << "Введите год ещё заново: "; std::cin >> year;
            }
            std::cout << "Месяц: "; std::cin >> month;
            while(month < 1 || month > 12)
            {
                std::cout << "Введите месяц заново: "; std::cin >> month;
            }
            std::cout << "День: "; std::cin >> day;
            while(day < 1 || day > 31)
            {
                std::cout << "Введите день заново: "; std::cin >> day;
            }
            std::cout << "Рейтинг: "; std::cin >> aScore;
            while(aScore < 0 && aScore > 100)
            {
                std::cout << "Введите средний рейтинг заново: "; std::cin >> aScore;
            }
            addStudent << sName << " " << fName << " " << id     << " " << year  << " "
                       << month << " " << day   << " " << aScore << "\n";
        }
    }
    if(choice == '2') //Вывод списка по дате (по возрастанию)
    {
        quant = 0;
        std::ifstream addToArr("data.txt");
        std::ifstream count("data.txt");
        std::cout << "\nОтсортированный список по дате рождения.\n\n";
        countS(count, quant);
        int** M = new int*[quant];
        for(int i = 0; i < quant; i++)
            M[i] = new int[3];
            
        while(addToArr >> sName >> fName >> id >> year >>
                          month >> day   >> aScore)
        {
            M[index][0] = year;
            M[index][1] = month;
            M[index][2] = day;
            index++;
        }
        
        for(int i = 0; i < quant; i++)
        {
            for(int j = i; j < quant; j++)
            {
                if(M[i][0] < M[j][0])
                {
                    int temp = M[i][0];
                    M[i][0] = M[j][0];
                    M[j][0] = temp;
                    
                    int temp1 = M[i][1];
                    M[i][1] = M[j][1];
                    M[j][1] = temp1;
                    
                    int temp2 = M[i][2];
                    M[i][2] = M[j][2];
                    M[j][2] = temp2;
                }
                if(M[i][0] == M[j][0] &&
                   M[i][1] < M[j][1])
                {
                    int temp1 = M[i][1];
                    M[i][1] = M[j][1];
                    M[j][1] = temp1;
                    
                    int temp2 = M[i][2];
                    M[i][2] = M[j][2];
                    M[j][2] = temp2;
                }
                if(M[i][0] == M[j][0] &&
                   M[i][1] == M[j][1] &&
                   M[i][2] < M[j][2])
                {
                    int temp = M[i][2];
                    M[i][2] = M[j][2];
                    M[j][2] = temp;
                }
            }
        }
        
        for(int i = 0; i < quant; i++)
        {
            y = M[i][0];
            m = M[i][1];
            d = M[i][2];
            std::ifstream printSortedList("data.txt");
            while(printSortedList >> sName >> fName >> id >> year >>
                                     month >> day   >> aScore)
            {
                if(y == year &&
                   m == month &&
                   d == day)
                {
                    std::cout << " " << sName << " " << fName << " " << id     << " " << year  << "/"
                              << month << "/" << day   << " --- " << aScore << "\n";
                }
            }
        }
        
        for(int i = 0; i < quant; i++)
            delete [] M[i];
        
        delete [] M;
    }
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.02.2014, 23:28
Привет! Вот еще темы с ответами:

Возвращение одного значения из базы данных - C#
Допустим пишу SQL запрос SELECT Фамилия FROM Список WHERE ='32' Этим запрсом я верну человека который у меня 32 в списке,так вот...

Можно ли узнать, как устроены связи в таблицах, уже существующей базы данных в microsoft sql? - SQL Server
У меня задача, осознать структуру БД. Таблиц очень много, и мне для понимая, не помешала бы структура связей между ними. Можно ли...

Запрос по датам рождения - SQL Server
Здравствуйте! Помогите, пожалуйста, с таким запросом: вывести студентов, рождённых между 29 августа и 16 декабря. select Stud_fam,...

Добавление введенных данных в список - JavaScript
Необходимо реализовать такую штуку: есть два поля ввода, при нажатии на кнопку надо брать данные из этих полей и добавлять в какой-то...


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

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

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