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


 

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

28914. Основные направления внешней политики России в новой геополитической ситуации (1991–2002 гг.) 43.5 KB
  Провозглашалась невозможность решения международных проблем силовыми методами. Универсальным способом решения международных вопросов объявлялся баланс интересов приоритет общечеловеческих ценностей над классовыми. Конструктивное решение международных проблем возможно только путем мирных переговоров путем учета законных национальных интересов всех стран мира. В этих условиях неимоверно возрастает роль ООН в решении международных проблем.
28915. Февральская революция 1917 г. и свержение самодержавия 38.5 KB
  Специфика исторического процесса в России спрессовала во времени и пространстве фундаментальные проблемы общественного преобразования разных эпох. Особую остроту и зрелость революционной ситуации в России к началу 1917 г. Заявив что судьбу политического строя в России должно решать Учредительное собрание. Самодержавие в России окончательно пало.
28916. Россия от февраля до октября 1917 г. Альтернативы развития страны 43.5 KB
  В ходе февральской революции в России сложилось двоевластие: временное правительство орган диктатуры буржуазии и помещиков; советы рабочих солдатских депутатов орган власти трудящихся. Возникает вторая альтернатива: установление жесткой диктаторской власти опирающейся на военщину. В конце августаначале сентября Петроградский и Московский Советы приняли резолюцию о взятии всей полноты власти. В ответ была предпринята попытка усиления центральной власти.
28917. Гражданская война в России (1918-1920 гг.) 42.5 KB
  Гражданская война в России 19181920 гг. €œСоюз защиты Родины и свободы€ под руководством эсера Савинкова €œСоюз освобождения России€ объединивший кадетов меньшевиков эсеров. На юге России и Северном Кавказе генералы Алексеев и Корнилов начали формировать Добровольческую армию ставшую основой белого движения. Страны Антанты подписали соглашение о непризнании Брестского мира и будущем разделе России на сферы влияния.
28918. Формирование однопартийного политического режима (1917-1940 гг.) 39.5 KB
  Это привело к подчинению государственных структур партии. Этот процесс шел параллельно с тенденцией превращения диктатуры пролетариата в диктатуру партии. В условиях однопартийной системы Советы превратились в придаток партии. Советы же оказываются лишь рычагом в руках партии для управления государством.
28919. Социально-экономическая политика советского государства (1921-1941 гг.) 41.5 KB
  Речь шла о необходимости превращения СССР из страны ввозящий машины и оборудование в страну производящую их. На рубеже 2030 годов руководство страны приняло курс на форсирование индустриального развития. Руководство страны решило выдвинуть лозунг догнать и перегнать в кратчайшие сроки в техникоэкономическом отношении передовые капиталистические страны. За ним стояло желание в кратчайшие сроки любой ценой ликвидировать отсталость страны и построить новое общество.
28920. НАЦИОНАЛЬНАЯ ПОЛИТИКА СОВЕТСКОГО ГОСУДАРСТВА. ОБРАЗОВАНИЕ СССР 23 KB
  ОБРАЗОВАНИЕ СССР После Октябрьской революции и победы большевиков одним из первых декретов новой власти стала Декларация прав народов России провозглашавшая равенство и суверенность всех народов их право на самоопределение вплоть до отделения и образования самостоятельных государств свободное развитие всех национальных меньшинств. После Гражданской войны начался процесс объединительного движения которое привело к образованию новой российской государственности СССР. съезд полномочных представителей данных республик I съезд Советов Союза...
28921. Культурное строительство в СССР (1921-1941 гг.) 40.5 KB
  Советский период это сложное и противоречивое явление в развитии не только нашей истории но и культуры. Отличительной особенностью советского периода истории культуры является огромная роль в ее развитии партии и государства. Государство взяло на себя финансирование всех отраслей культуры: образование материальнотехническое обеспечение все виды искусства установив строжайшую цензуру над литературой театром кинематографом учебными заведениями и т. В спецхранилищах оказались произведения писателей художников и других представителей...
28922. Советское государство и мир (1921-1941 гг.) 43.5 KB
  Согласно ему СССР поддерживал коммунистическое национально-освободительное движение в мире; прагматической концепции мирном сосуществовании государств с различным общественным строем. В результате СССР в основном сумел преодолеть состояние дипломатической изоляции. Япония развязала боевые действия против СССР и Монголии в районе реки ХалхинГол. для СССР стала реальной угроза войны на два фронта.