Разработка АСР

Автор работы: Пользователь скрыл имя, 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

Файлы: 7 файлов

ACP.docx

— 52.66 Кб (Скачать файл)

ACP.cs – основная форма ACP

using System;

using System.Collections;

using System.Collections.Generic;

using System.Data;

using System.Data.Odbc;

using System.Globalization;

using System.IO;

using System.Threading;

using System.Windows.Forms;

using ACP.Properties;

using DevExpress.XtraEditors.Controls;

using DevExpress.XtraTreeList;

using DevExpress.XtraTreeList.Nodes;

using PostgreSql.Data.PostgreSqlClient;

using RKLib.ExportData;

using Telerik.WinControls.UI;

using System.Data.OleDb;

using DevExpress.XtraTreeList.Columns; 

namespace ACP

{

    public partial class ACP : Form

    {

        DataSet ds_elektro = new DataSet();

        DataSet ds = new DataSet();

        DataTable dt = new DataTable();

        DataTable dt_elektro = new DataTable();

        DataSet ds_otch = new DataSet();

        DataSet ds_otch_totals = new DataSet();

        private int count;

  

        public delegate void DelegateSetProgress(object sender, int value); 

        public ACP()

        { 

            InitializeComponent();

            ImageList imageList = new ImageList();

            buttonEdit1.Text = Properties.Settings.Default.Mdb;

            ListNodes();

            Nodes_elektro();

            marqueeProgressBarControl1.Properties.Stopped = true; 
 
 
 

        }

  

     

        public void CheckTable(string table_name)

        {

            PgConnection conn = new PgConnection("Server=" + Properties.Settings.Default.Server + ";Port=" + Properties.Settings.Default.Port + ";User Id=" + Properties.Settings.Default.User_id + ";Password=" + Properties.Settings.Default.Password + ";Database=" + Properties.Settings.Default.Database);

            conn.Open();

            PgCommand command_check = new PgCommand("SELECT 1 FROM pg_tables WHERE tablename = " + table_name, conn);

            int t = command_check.ExecuteNonQuery();

       

            conn.Close();

        }

      

        public void Nodes()

        {

            PgConnection conn = new PgConnection("Server=" + Properties.Settings.Default.Server + ";Port=" + Properties.Settings.Default.Port + ";User Id=" + Properties.Settings.Default.User_id + ";Password=" + Properties.Settings.Default.Password + ";Database=" + Properties.Settings.Default.Database);

            conn.Open(); 

            PgCommand pg_db = new PgCommand("SELECT COUNT(*) FROM nodes_prolog", conn);

            PgDataAdapter pg_da = new PgDataAdapter("SELECT id,abon_id,name_node FROM nodes_prolog", conn);

            PgDataReader dr = pg_db.ExecuteReader();

            dr.Read();

     

            pg_da.Fill(ds);

    

          

        

            dt = ds.Tables[0]; 

         

            conn.Close(); 

        }

 

        public void ListNodes()

        {

           

            Nodes();

         

     

                FillTreeView(dt);

      

            ds.Clear(); 

        } 

        public void Progress()

        {

            progressBarControl2.PerformStep();

            progressBarControl2.Update();

        }

      

        public void FillTreeView(DataTable dt)

        {

          

            DataRow[] rows = dt.Select("abon_id = 0"); 

         

            foreach (DataRow row in rows)

            { 

               

                TreeListNode parentNode = treeList1.AppendNode(new object[] { row["id"], row["abon_id"], row["name_node"],false }, null); 

                parentNode.Tag = row["id"];

          

           

                FillNode(parentNode, dt);

            }

         

        } 

    

  

        public void FillNode(TreeListNode parentNode, DataTable dt)

        { 

            DataRow[] rows = dt.Select(string.Format("abon_id = {0}", parentNode.Tag)); 

            foreach (DataRow row in rows)

            {

                

                TreeListNode parent_Node = treeList1.AppendNode(new object[] { row["id"], row["abon_id"], row["name_node"],false }, parentNode);

                parent_Node.Tag = row["id"];

              

            }

           

        }

        private void radMenuItem2_Click(object sender, System.EventArgs e)

        { 

           

            Nodes();

         

        }

        //Автоматическая вставка нодов в базу

        private void InsertIntoNodes(int parent_id, int type, int model, int device_id,

Диплом.docx

— 620.40 Кб (Просмотреть файл, Скачать файл)

Приложение _А.docx

— 14.16 Кб (Просмотреть файл, Скачать файл)

Хранимые процедуры.docx

— 22.02 Кб (Просмотреть файл, Скачать файл)

~$Диплом.docx

— 162 байт (Скачать файл)

Информация о работе Разработка АСР