33161

ADO.NET

Лекция

Информатика, кибернетика и программирование

Создать таблицу, связанную с таблицей элемента контейнера отношением «один ко многим» (Например, если таблицей для хранения элементов контейнера является таблица Книга, то связанная с ней отношением «один ко многим» может быть таблица АвторКниги, т.к. один автор может написать много книг).

Русский

2014-08-21

96 KB

4 чел.

Лабораторная работа № 4

ADO.NET

по курсу «Компонентные технологии программного обеспечения»

  1.  Цель работы

Изучить архитектуру и возможности библиотеки ADO.NET.

Познакомиться с технологией Data Binding для реляционных баз данных.

  1.  Порядок выполнения работы

Выполнить лабораторную работу № 3.

Создать базу данных в формате Microsoft SQL Server Compact Edition.

  1.  Создать в базе данных таблицу для хранения полей элементов контейнера лабораторной работы № 3.
    1.  Создать таблицу, связанную с таблицей элемента контейнера отношением «один ко многим» (Например, если таблицей для хранения элементов контейнера является таблица Книга, то связанная с ней отношением «один ко многим» может быть таблица АвторКниги, т.к. один автор может написать много книг).
    2.  Ввести минимум десять строк в каждую из созданных таблиц.

Создать базу данных в формате Microsoft Access.

  1.  Создать таблицы полностью идентичные (имена таблиц, имена и типы столбцов) таблицам базы данных формата SQL Server Compact Edition.
    1.  Ввести минимум десять строк в каждую из созданных таблиц.

Создать типизированный DataSet, отражающий таблицы базы данных.

Реализовать функцию открытия файлов баз данных как в формате Microsoft SQL Server Compact Edition так и в формате Microsoft Access. При открытии файлов баз данных различных форматов, рекомендуется изменять только свойство Connection каждого из объектов TableAdapter, структура DataSet и логика работы приложения в целом, при этом изменяться не должны.

Для каждой таблицы базы данных создать соответствующую форму. Используя технологию Data Binding, реализовать функции просмотра, добавления, изменения и удаления записей таблиц.

Создать форму, отображающую связанные таблицы базы данных (п. ).

  1.  Содержание отчета

Номер и название лабораторной работы, номер группы и ФИО студента.

Цель работы.

Постановка задачи.

Краткие теоретические сведения о библиотеке ADO.NET.

Краткое описание предметной области созданной базы данных.

Диаграмма базы данных созданного DataSet.

Текст программы и пример ее работы.

Анализ результатов и выводы.

  1.  Краткие теоретические сведения
    1.  Подключение к базе данных

Для подключения к источнику данных используются потомки абстрактного класса System.Data.Common.DbConnection:

  •  System.Data.EntityClient.EntityConnection – подключение к концептуальной модели базы данных (Entity Framework). В данной лабораторной работе не используется.
  •  System.Data.Odbc.OdbcConnection – подключение к источнику данных посредством ODBC драйвера.
  •  System.Data.OleDb.OleDbConnection – подключение к OLE DB провайдеру данных.
  •  System.Data.OracleClient.OracleConnection – подключение к базе данных Oracle.
  •  System.Data.SqlClient.SqlConnection – подключение к базе данных MS SQL Server.

Пример использования OleDbConnection смотри в «.\Lectures\04-ADO.NET\Demo\DbSample\ DbSample\DbSample.cs

  1.  Создание и заполнение таблиц DataSet

Для заполнения таблиц DataSet необходимо:

Создать типизированный DataSet.

Вызовите контекстное меню для проекта, который будет содержать создаваемый DataSet.

Выберете «Add\New Item».

Выберете «DataSet», укажите имя создаваемого DataSet, нажмите «Add».

Создать таблицы DataSet на основе таблиц существующего источника данных.

Открыть окно «Server Explorer».

Создать подключение к существующему источнику данных.

Вызвать контекстное меню для узла «Data Connections».

Выбрать «Add Connection».

В поле «Data source»указать тип источника данных, нажав кнопку «Change» и выбрав необходимый «Data provider».

Если того требует Data provider, указать «Server name»,«User name»,«Password» и «database name».

Нажать «OK»

Двойным щелчком мыши откройте созданное подключение.

Откройте узел «Tables».

Выделите таблицы, данные которых будут записываться в таблицы созданного DataSet.

Перетащите выделенные таблицы из окна «Server Explorer» в область «DataSet Designer» созданного DataSet. Для каждой выделенной таблицы будут автоматически сгенерированы соответствующие таблица и TableAdapter.

Заполнить таблицы, используя метод Fill() или GetData() класса TableAdapter, соответствующего заполняемой таблице.

  1.  Сохранение изменений данных таблиц DataSet

Для сохранения изменений из таблицы DataSet в источник данных необходимо использовать методы и свойства класса TableAdapter, соответствующего сохраняемой таблице:

Установить (подкорректировать) значения CommandText свойств InsertCommand, UpdateCommand, DeleteCommand класса TableAdapter.

Вызвать метод TableAdapter.Update().

  1.  Реализация параметризированных запросов к нескольким таблицам

Для выполнения параметризированных запросов на объединение нескольких таблиц источника данных необходимо:

Вызвать контекстное меню «DataSet Designer».

Выбрать пункт меню «Add\TableAdapter».

Выполнить пошагово мастер «TableAdapter Configuration Wizard».

Выбрать существующее соединение или создать новое.

Выбрать тип команды «Use SQL statements».

Ввести SQL выражение, использовав при необходимости «Query Builder».

Указать перечень автоматически генерируемых методов (Fill(), GetDta()).

В результате работы мастера будут созданы DataTable и TableAdapter, соответствующие структуре введенного SQL выражения на объединение нескольких таблиц.

Выделите созданный TableAdapter, откройте окно «Properties Window».

Для свойства SelectCommand выберете свойство «Parameters», добавьте необходимые параметры

Используете добавленные параметры при редактировании свойства SelectCommand.CommandText.

  1.  Data Binding для реляционных баз данных

Для начального знакомства с технологией Data Binding для реляционных баз данных изучите лекционную презентацию []. Уясните работу лекционного демонстрационного приложения []. Это приложение демонстрирует следующие возможности Data Binding для Windows Forms:

  •  Создание форм для работы с базой данных Books.

База данных Books является локальной базой данных формата SQL Server Compact Edition и располагается в файле «Books.sdf». База данных Books хранит информацию о книгах и содержит всего две таблицы: таблицу Author (автор книги) и таблицу Book (название книги). Таблица Book содержит внешний ключ, связывающий ее с таблицей Author.

  •  Наследование форм.

Наследование форм используется с целью инкапсуляции общей для нескольких форм функциональности в базовой форме. Например, в рассмотренном приложении [], базовую функциональность форм, отображающих данные справочников, можно поместить в классе DictionaryForm. Форма DictionaryForm является родительской для форм AuthorForm и BookForm.

  •  Создание форм, отображающих связанные таблицы базы данных.

В рассмотренном демонстрационном приложении [] примерами форм, отображающих связанные таблицы базы данных, являются формы AuthorBookForm и BookForm. Для создания форм, отображающих зависимость Master/Detail и использующих компонент DataGridView, можно воспользоваться статьей [].

Пример использования событий Control.Validating, Control.Validated и компонента ErrorProvider смотри в [].

  1.  Контрольные вопросы

Каковы отличительные черты, принцип работы следующих технологий доступа к данным: ODBC, OLE DB, ADO?

Каковы отличительные черты и принцип работы ADO.NET?

Что представляет собой и из каких элементов состоит DataSet? Что такое типизированный DataSet?

Каково назначение следующих классов DataProvider: Connection, Command, DataReader, DataAdapter?

Каково назначение следующих элементов DataTable: DataColumns, Constraints, DataRows?

Каковы основные свойства класса Connection? Что хранится в свойстве ConnectionString?

Каково назначение следующих методов класса Command: ExecuteNonQuery(), ExecuteScalar(), ExecuteReader()?

Для чего используется класс DataReader? Как создать объект данного класса?

Для чего используется класс DataAdapter? Каково назначение методов Fill() и Update(), а также свойств SelectCommand, InsertCommand, DeleteCommand, UpdateCommand класса DataAdapter?

Каково назначение следующих свойств класса Command: CommandType, CommandText, Connection?

Что представляют собой следующие возможные значения свойства Command.CommandType: Text, StoredProcedure, TableDirect?

Каково назначение свойства Command.Parameters? Что представляет собой связывание параметра по индексу и по имени?

Каково назначение класса DataRelation? Каково назначение методов DataRow.GetChildRows(DataRelation) и DataRow.GetParentRows(DataRelation)?

Каково назначение следующих видов Constraints: UniqueConstraint, ForeignKeyConstraint? Что представляют собой следующие возможные значения свойств AcceptRejectRule, DeleteRule, UpdateRule класса ForeignKeyConstraint: None, Cascade, SetNull, SetDefault?

Каково назначение следующих возможных значений DataRowVersion: Original, Current? Для чего используются методы AcceptChanges() и RejectChanges() классов DataRow, DataTable и DataSet?

Каково назначение следующих возможных значений свойства DataRow.RowState: Detached, Unchanged, Added, Deleted, Modified?

Каково назначение свойств DataView.RowFilter и DataView.Sort? Приведите примеры использования этих свойств.

Что такое транзакция? Каков смысл основных свойств транзакций ACID (Atomic, Consistent, Isolated, Durable)?

Каково назначение следующих методов: Connection.BeginTransaction(), ITransaction.Commit(), Transaction.Rollback()?

Каково назначение следующих методов класса DataSet: ReadXml(), ReadXmlSchema(), WriteXml(), WriteXmlSchema()?

  1.  Упражнения

Для выполнения упражнений создать консольное приложение и типизированный DataSet, использующий базу данных «.\Lectures\04-ADO.NET\Demo\DbSample\DbSample\Books.mdb». За образец программы можно взять «.\Lectures\04-ADO.NET\Demo\DbSample\DbSample\ DbSample.cs».

Вывести на экран список авторов книг из таблицы «Authors».

Выполнить SQL запрос, извлекающий книги из таблицы «Books», названия которых начинаются с заданной подстроки. Вывести на экран названия полученных книг.

Вывести на экран список названий книг заданного автора.

Добавьте новую запись в DataTable «Books». Сохраните изменения в исходной базе данных.

Измените запись в DataTable «Books». Сохраните изменения в исходной базе данных.

Удалите запись из DataTable «Books». Сохраните изменения в исходной базе данных.

Откройте транзакцию. Добавьте нового автора в DataTable «Authors» и книгу этого же автора в DataTable «Books». Сохраните внесенные изменения в источник данных. Зафиксируйте транзакцию, если сохранение завершилось без ошибок, и откатите транзакцию в противном случае.

  1.  Литература

Лекционная презентация «.\Lectures\04-ADO.NET\04-ADO.NET.pptx».

Лекционное демонстрационное приложение «.\Lectures\03-Windows Forms\Demo\WindowsForms\WindowsForms.sln».

Лекционное демонстрационное приложение «.\Lectures\04-ADO.NET\Demo\DbSample\ DbSample.sln».

MSDN, «Walkthrough: Creating a Master/Detail Form Using Two Windows Forms DataGridView Controls».

MSDN, «How to: View Errors Within a DataSet with the Windows Forms ErrorProvider Component»

абораторная работа № 4. ADO.NET 4


 

А также другие работы, которые могут Вас заинтересовать

20498. Таблиці та дерева рішень 38.5 KB
  Метод дерева рішень це один з методів автоматичного аналізу величезних масивів даних. Область використання методу дерева рішень можна об'єднати в три класи: опис даних: застосування дерева рішень дозволяє зберігати інформацію про вибірку даних в компактній і зручній для обробки формі що містить в собі точні описи об'єктів; класифікація: застосування дерева рішень дозволяє справитися із завданнями класифікації тобто відношення об'єктів до одного з описаних класів; регресія: якщо змінна має недостовірні значення то застосування дерева...
20499. Теорія реляційних баз даних. Основні терміни і означення. Нормалізація відношень 31 KB
  Реляційна база даних база даних основана на реляційній моделі даних. Інакше кажучи реляційна база даних це база даних яка сприймається користувачем як набір нормалізованих відношень різного ступеню. Метою нормалізації є усунення недоліків структури БД які призводять до шкідливої надмірності в даних яка в свою чергу потенційно призводить до різних аномалій і порушень цілісності даних.
20500. Трикутні матриці (верхня та нижня) і їх розклад на добуток двох трикутних 37 KB
  Трику́тна ма́триця матриця в якій всі елементи нижче або вище за головну діагональ рівні нулю. Верхньотрикутна матриця квадратна матриця в якій всі елементи нижче за головну діагональ дорівнюють нулю. Нижньотрикутна матриця квадратна матриця в якій всі елементи вище за головну діагональ дорівнюють нулю. Унітрикутна матриця верхня або нижня трикутна матриця в якій всі елементи на головній діагоналі дорівнюють одиниці.
20501. Форми, типи форм, обчислення в формах 33 KB
  Робота з формами може відбуватися в трьох режимах: у режимі Форми в режимі Таблиці в режимі констриктор. типи форм В Access можна створити форми наступних видів: форма в стовпець або повноекранна форма; стрічкова форма; таблична форма; форма головна підпорядкована; зведена таблиця; формадіаграма. Форма в стовпець є сукупністю певним чином розташованих полів введення з відповідними їм мітками і елементами управління.
20502. Маніпулювання даними, операції над схемою бази даних за допомогою мови SQL 27.5 KB
  Маніпулювання даними операції над схемою бази даних за допомогою мови SQL Для маніпулювання данними виділяють такі групи команд SQL:Команди мови визначення даних DDL Data Definition Language. DDL Data Definition Language мова визначення даних це підмножина SQL що використовується для визначення та модифікації різних структур даних.До даної групи відносяться команди призначені для створення зміни та видалення різних об'єктів бази даних. Команди CREATE створення ALTER модифікація і DROP видалення мають...
20503. Матриця суміжності та матриця інцидентності 28 KB
  Матриця суміжності графа G зі скінченною кількістю вершин n пронумерованих числами від 1 до n це квадратна матриця A розміру n в якій значення елементу aij рівне числу ребер з iї вершини графа в jу вершину. Матриця суміжності простого графа що не містить петель і кратних ребер є бінарною матрицею і містить нулі на головній діагоналі. Матриця суміжності неорієнтованого графа симетрична а значить володіє дійсними власними значеннями і ортогональним базисом з власних векторів.
20504. Метод ітерації (метод послідовних наближень) 88 KB
   Суть методу полягає у заміні початкового рівняння 4.18 еквівалентним йому рівнянням 4.19 Постановка задачі Нехай задано рівняння де – неперервна нелінійна функція. Потрібно визначити корінь цього рівняння який знаходиться на відрізку з заданою похибкою .
20505. Метод послідовних наближень (метод ітерацій) для розв’язку системи лінійних рівнянь 91 KB
  11 пошуку розв’язку системи с заданою похибкою відповідно теоремі про збіжність.11 виконується то ітераційний процес пошуку розв’язку системи с заданою похибкою збігається і метод послідовних наближень можна використовувати.13 що легко розв’язується для знаходження вектора розв’язку першого наближення тому що в правої частині містить всі визначені елементи.
20506. Мова запитів SQL. Огляд її можливостей 27 KB
  Він по суті містив тільки пропозиція SELECT яке дозволяло формулювати запити для вибірки даних з бази. Потім мова була доповнено двома іншими компонентами необхідними для роботи з базами даних. Перший з них – компонент для визначення структури бази даних які в термінології теорії баз даних називаються мовою визначення даних МВД. Другий засоби що дозволяють заповнювати базу даних змінювати їх і видаляти.