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


 

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

4136. Шифраторы и дешифраторы 375.5 KB
  Шифраторы и дешифраторы Шифратор – специфический преобразователь кодов, - устройство, обеспечивающее выдачу определенного кода в ответ на возбуждение одного из входов. Шифраторы реализуют преобразование унитарного кода (другое название – к...
4137. Дослідження роботи служби www 107.91 KB
  Дослідження роботи служби www 1.Мета роботи Дослідити різноманітні види пошуку та пошукових систем, які використовуються в Internet Хід роботи Досить вказати пошуковий запит і клацнути мишкою на відповідній кнопці, на екрані буде відобра...
4138. Санітарний паспорт кабінету інформатики та інформаційно-комунікаційних технологій 43.5 KB
  Санітарний паспорт кабінету інформатики та інформаційно-комунікаційних технологій Паспортна частина Адреса: Смільчинецький навчально-виховний комплекс Черкаська обл. Лисянський район, с.Смільченці Побудована: по типовому проекту Розташ...
4139. Вивчення закону Ома 110.5 KB
  Вивчення закону Ома Мета роботи. Встановити залежність сили струм від напруги у зразку з монокристалу визначеної речовини та визначити його опір, питому електропровідність та концентрацію носіїв струму. Теоретичні відомості. Електричним струмом пров...
4140. Дослідження залежності моменту інерції тіла від положення осі обертання 192.5 KB
  Дослідження залежності моменту інерції тіла від положення осі обертання Мета роботи. Визначити момент інерції тіла при трьох різних положеннях осі обертання. Теоретичні відомості. Вектор лінійної швидкості спрямований по дотич...
4141. Мультиплексоры и демультиплексоры 372.5 KB
  Мультиплексоры и демультиплексоры относятся к классу комбинационных устройств, которые предназначены для коммутации потоков данных в линиях связи по заданным адресам. Большая часть данных в цифровых системах передае...
4142. Робота зі спільними ресурсами в середовищі Windows 2000/XP 60.68 KB
  Робота зі спільними ресурсами в середовищі Windows 2000/XP Мета навчитисьвідкривати доступ до ресурсів компьютера тавикористовуватимережеві ресурси в ОС Windows. Хід роботи Завдання Створюємо в своєму каталозі папку і наз...
4143. Приклад обєктно-орієнтованої розробки 93.5 KB
  Початок Віконний інтерфейс користувача(WUІ) - середовище, кероване подіями. Дії в середовищі ініціюються функціями зворотного виклику, що викликаються у відповідь на подію - користувальницьке введення. Ядром WUІ є цикл обробки подій, що організуєтьс...
4144. Дослідження електричного поля 175.5 KB
  Дослідження електричного поля Мета роботи. Провести експериментальне дослідження електричного поля простої геометричної форми отримати графічну схему розподілу силових лiнiй та лiнiй однакового потенціалу за допомогою електричного зонду...