Автор работы: Пользователь скрыл имя, 28 Декабря 2011 в 11:16, дипломная работа
В дипломном проекте рассмотрены общие подходы к реализации распределенных систем обработки данных на базе технологии клиент-сервер, а также задача создания действующей информационной системы на примере системы автоматизации расчетов с теплоснабжающими организациями предприятия ООО Альтернатива. Актуальность построения этой системы обусловлена резким ростом количества абонентов на информационное обслуживание предприятия ООО Альтернатива
Введение 4
1 Анализ технического задания 5
1.1 Техническое задание 5
1.2 Общие выводы из технического задания 5
2 Подходы к проектированию баз данных 6
2.1 Основные понятия теории реляционных баз данных 6
2.2 Сервер базы данных 10
2.2.1 Технология и модели "клиент-сервер" 10
2.2.2 Механизмы реализации активного ядра 18
2.2.3 Хранимые процедуры 19
2.2.4 Правила (триггеры) 20
2.2.5 Механизм событий 21
2.3 Обработка распределенных данных 21
2.4 Взаимодействие с PC-ориентированными СУБД 28
2.5 Обработка транзакций 31
2.6 Средства защиты данных в СУБД 35
2.7 Применение CASE-средств для информационного моделирования в системах обработки данных. 39
3 Реализация базы данных 40
3.1 Анализ существующей системы 41
3.2 Новая схема обмена информацией 42
3.3 Выбор операционной системы 42
3.4 Выбор сервера баз данных 43
3.5 Выбор средств разработки 44
3.6 Проектирование структуры базы данных 44
4 Реализация клиентского приложения 45
4.1 Назначение и состав клиентского приложения 45
4.2 Безопасность доступа к данным 45
4.2.1 Идентификация 45
4.2.2 Авторизация 46
4.2.3 Управление доступом на основе ролей 47
4.3 Алгоритм работы приложения 48
5 Разработка таблиц 48
5.1 Структура таблицы “nodes_prolog” 49
5.2 Структура таблицы “nodes_elektro” 50
5.3 Структура таблицы “ elektro_pokaz” 50
5.4 Структура таблицы “t943_name” 51
5.5 Структура таблицы “t942_name” 52
5.6 Структура таблицы “t943_name_totals” 52
5.7 Структура таблицы “t942_name_totals” 53
6 Руководство оператора 54
6.1 Запуск приложения 54
6.2 Начало работы 55
7 Экономическая часть 60
7.1 Особенности программного продукта как товара 60
7.2 Расчет затрат на изготовление подсистемы 60
7.3 Расчет экономической эффективности 69
8 Безопасность жизнедеятельности. Природопользование и охрана окружающей среды. 71
8.1 Краткое содержание дипломного проекта 71
8.2 Безопасность проекта 72
8.2.1 Вредные и опасные производственные факторы при работе с ПЭВМ 72
8.2.2 Электро- и пожаробезопасность на рабочем месте оператора ПЭВМ 73
8.2.2.1 Электробезопасность на рабочем месте 74
8.2.2.2 Пожарная безопасность на рабочем месте 76
8.2.3 Обеспечение микроклимата на рабочем месте. Освещенность, шум, вибрация 78
8.2.4 Расчет освещенности на рабочем месте оператора 79
8.2.4.1 Вводная часть 79
8.2.4.2 Описание помещения, в котором располагается рабочее место 79
8.2.4.3 Расчет освещенности на рабочем месте 80
8.2.4.4 Особенности освещения рабочих мест с видеотерминальными устройствами 82
8.2.4.5 Заключение 82
8.3 Эргономичность проекта 83
8.4 Природопользование проекта. Работа с видеодисплейными терминалами ПЭВМ. 85
8.5 Выводы по разделу 87
9 Выводы по выполненной работе 88
10 Список использованных источников 89
+ ReplaceCommit(row["v2"].
+ ReplaceCommit(row["m2"].
+ ReplaceCommit(row["Tи"].
command_insert = new PgCommand("SELECT insert_into_t943_totals(" + query_insert + ");", conn);
command_insert.
}
progressBarControl2.EditValue = progress_count;
command_insert.Dispose();
Application.DoEvents();
progress_count++;
}
dt.Dispose();
progressBarControl2.EditValue = 0;
progressBarControl2.
}
//Получение показаний приборов по parent_id , типу устройства и виду значений
private void Load_Access_Indications(int parent_id, int d_type, OleDbConnection o_conn, PgConnection conn, string full_table_name)
{
OleDbDataAdapter o_da =
new OleDbDataAdapter("SELECT * FROM NODES", o_conn);
DataSet o_ds = new DataSet();
DataTable
o_dt = new DataTable();
string[] table_name = full_table_name.Split('\'');
PgCommand command_insert = new PgCommand("SELECT MAX(date_t) FROM "+table_name[1], conn);
PgDataReader dr_last_date = command_insert.ExecuteReader()
if(dr_last_date.Read())
{
if (dr_last_date[0] != System.DBNull.Value)
{
dateEdit1.DateTime = Convert.ToDateTime(dr_last_
}
}
if (d_type == 2)
{
if (dr_last_date[0] != System.DBNull.Value)
{
o_da =
new OleDbDataAdapter(
"SELECT * FROM t942_archive
WHERE parent_id = " +
parent_id, o_conn);
}
else
{
o_da =
new OleDbDataAdapter(
"SELECT * FROM t942_archive WHERE parent_id = " + parent_id, o_conn);
}
o_da.Fill(o_ds);
o_dt = o_ds.Tables[0];
o_da.Dispose();
Insert_Into_Postgresql(o_dt, conn, full_table_name, d_type);
}
if (d_type == 9)
{
//t943
if (dr_last_date[0] != System.DBNull.Value)
{
o_da =
new OleDbDataAdapter(
"SELECT * FROM t943_archive WHERE parent_id = " + parent_id, o_conn);
}
else
{
o_da =
new OleDbDataAdapter("SELECT * FROM t943_archive WHERE parent_id = " + parent_id, o_conn);
}
//t_942
o_da.Fill(o_ds);
o_dt = o_ds.Tables[0];
o_da.Dispose();
Insert_Into_Postgresql(o_dt, conn, full_table_name, d_type);
}
if (d_type == 22)
{
//t_942_totals
o_da =
new OleDbDataAdapter("SELECT * FROM t942_totals WHERE parent_id = " + parent_id, o_conn);
o_da.Fill(o_ds);
o_dt = o_ds.Tables[0];
o_da.Dispose();
Insert_Into_Postgresql(o_dt, conn, full_table_name, d_type);
}
if (d_type == 99)
{
//t943_totals
o_da =
new OleDbDataAdapter("SELECT * FROM t943_totals WHERE parent_id = " + parent_id, o_conn);
o_da.Fill(o_ds);
o_dt = o_ds.Tables[0];
o_da.Dispose();
Insert_Into_Postgresql(o_dt, conn, full_table_name, d_type);
}
}
private void load_data_Click(object sender, EventArgs e)
{
if
(Properties.Settings.Default.
{
int device_id = 0;
int type_device = 0;
int parent_id = 0;
string table_name;
string
connection_mdb = "Provider=Microsoft.Jet.OLEDB.
OleDbConnection o_conn = new OleDbConnection(connection_
o_conn.Open();
PgConnection conn =
new PgConnection("Server=" + Properties.Settings.Default.
conn.Open();
for
(int r = 0; r < checkedListBoxControl1.
{
string[]
s = checkedListBoxControl1.