33161

ADO.NET

Лекция

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

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

Русский

2014-08-21

96 KB

5 чел.

Лабораторная работа № 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


 

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

51155. Возрастная психология. Лабораторный практикум 227.81 KB
  Интерпретацию непроизвольного рисунка можно использовать для выяснения подробностей жизни ребенка или для выяснения того насколько взрослый человек переживает то или иное событие. Юнгу особенности личности ребенка и формами его художественного выражения. Юнгу особенности личности ребенка и формами его художественного выражения. Обычно опрос перерастает в беседу о жизненных представлениях ребенка.
51156. Система управления базами данных ACCESS 324.42 KB
  Установите типы данных счетчик текстовый числовой и т. созданных таблиц. Определите первичные ключи в созданных таблицах.
51157. Аналитическое определение различных видов теплоемкостей 3.1 MB
  Ознакомление с одним из методов экспериментального определения теплоемкости воздуха. Аналитическое определение различных видов теплоемкостей, определение средней теплоемкости по таблицам.
51158. ПРИМЕНЕНИЕ ХАРАКТЕРИОГРАФА ДЛЯ ИССЛЕДОВАНИЯ ВАКУУМНЫХ И ТВЕРДОТЕЛЬНЫХ ПРИБОРОВ 6.38 MB
  Сущность характериографических исследований заключается в приложении к объекту исследования изменяющегося напряжения вызывающего ток протекающий через объект с последующим отображением зависимости этого тока от напряжения в прямоугольной системе координат.1 Исследуемый объект Здесь исследуемый объект подключён к генератору линейно изменяющегося напряжения ГЛИН. Если подать линейно изменяющееся напряжение например на входы горизонтального отклонения луча электроннолучевой трубки осциллографа X а напряжение с измерительного...
51159. Дослідження текстового та графічного режимів роботи EPSON-сумісних матричних принтерів 26.69 KB
  Специальные функции передаются на ПУ сериями Escpe Серия Escpe состоит из кода Escpe 1B и буквенноцифровых знаков или символов. Виды шрифтов SO выход из основного набора ИСО включение широкого шрифта ESC SO включение широкого шрифта SI вход в основной набор ИСО включение уплотненного шрифта ESC SI включение уплотненного шрифта DC2 выключение уплотненного шрифта DC4 выключение широкого шрифта ESC E включение жирного шрифта ESC F выключение жирного шрифта ESC G включение двойной печати ESC H выключение двойной...
51161. ОПЕРАЦИОННЫЙ БЛОК МИКРОПРОГРАММИРУЕМОГО ПРОЦЕССОРА 127.5 KB
  Определить количество нулей в коде числа. Используемые регистры R0=Число в котором будет определяться колво нулейC000 h R2=10 h R3=0 Тесты: R0=C000 R2=000E; R0=FFFF R2=0000; R0=0000 R2=0010; R0=FBE R2=0004; Выводы: В данной работе был изучен операционного блока на уровне структурной схемы так же я ознакомился с составом микрокоманд и порядком их выполнения с составлением и отладкой микропрограммы. Был разработан и реализован алгоритм позволяющий определить количество нулей в коде числа и в соответствии с ним написана микропрограмма.