69088

ТЕХНОЛОГІЯ ДОСТУПУ ДО ДАНИХ ADO. NET. ОСНОВИ

Лекция

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

Доступ до даних, що зберігаються в зовнішніх джерелах, з програмного коду здійснюється за компонентною технологією ADO (ActiveX Data Objects). Ця технологія призначена для спрощення доступу до даних з програм. Вона є розширенням технології зв’язування об’єктів OLE...

Украинкский

2014-09-29

934.86 KB

23 чел.

6

ЛЕКЦІЯ 8. ТЕХНОЛОГІЯ ДОСТУПУ ДО ДАНИХ ADO. NET. ОСНОВИ

План

8.1. Об’єктна модель ADO .NET

8.2. Створення бази даних MS SQL Server в середовищі Visual Studio

8.3. Візуальні засоби доступу до даних. Зв'язування форми з джерелом даних

8.1 Об’єктна модель ADO .NET

Доступ до даних, що зберігаються в зовнішніх джерелах, з програмного коду здійснюється за компонентною технологією ADO (ActiveX Data Objects). Ця технологія призначена для спрощення доступу до даних з програм. Вона є розширенням технології зв’язування об’єктів OLE (Object Linking and Embedding), яка використовується на платформі Windows (компонентна модель COM).

Нова технологія ADO .NET спеціально розроблена для роботи з даними на платформі .NET Framework.

Модель об’єктів ADO .NET (ActiveX Data Objects .NET) – це набір класів, що реалізують програмні інтерфейси для полегшення підключення до баз даних та інших джерел даних.

Концепція доступу до даних в ADO .NET базується  на використанні двох компонентів:

  1.  НАБОРУ ДАНИХ (представляється об'єктом класу DataSet) збоку клієнта. Це локальне тимчасове сховище даних;
  2.  ПРОВАЙДЕРА ДАНИХ (представляється об'єктом класу .Net data provider). Це посередник, що забезпечує взаємодію програми і бази даних збоку бази даних (в розподілених застосуваннях – збоку сервера).

Клас DataSet це центральний компонент, який використовується для доступу до даних незалежно від джерела. Цей об'єкт містить об'єкти DataTable, які складаються з колонок і стовпців, а також первинного ключа, зовнішнього ключа, обмежень, інформації про зв’язки між таблицями тощо.

Компонент .Net data provider містить об'єкти, які явно розроблялися для найбільш ефективного доступу до баз даних. Об'єкт Connection забезпечує зв'язок з джерелом даних, об'єкт Command використовується для повернення даних. Об'єкт DataReader забезпечує потік даних з джерела, а DataAdapter - це міст між об'єктом DataSet і джерелом даних.

ADO .NET підтримує два типи джерел даних, і відповідно, дві множини класів:

SQL Managed Provider (SQL Server.NET Data Provider) – для роботи з Microsoft SQL Server 7.0 і вище;

ADO Managed Provider (OleDb.NET Data Provider) – для решти баз даних. Забезпечує роботу з довільними базами даних.

В об'єктній моделі ADO .NET є дві групи класів, що виконують чітко визначені задачі при роботі з базою даних (рис. 8.1):

- класи приєднаних об'єктів забезпечують встановлення з'єднання з базою даних і управління базою даних збоку застосування. Потребують постійного зв’язку з базою; 

- класи від'єднаних об'єктів забезпечують збереження, використання і перетворення отриманої від бази даних інформації на стороні застосування.

Рис. 8.1 – Ієрархія класів ADO .Net

Загалом, класи ADO.NET призначені для виконання набору задач:

- встановити з'єднання з базою даних;

- створити і заповнити даними об'єкт DataSet;

- відключитися від сховища даних;

- внести зміни в дані в об'єкті DataSet

- знову встановити з'єднання з базою даних і повернути внесені зміни назад в сховище даних.

Всі класи  ADO .NET об'єднані в декілька просторів імен (табл.8.1).

Таблиця 8.1. Простори імен для роботи з даними

Простір імен

Призначення

System.Data

Головний простір імен (ядро ADO .NET). містить класи, необхідні для зв'язку за допомогою будь-яких провайдерів даних. Ці класи представляють таблиці, рядки, стовпці, DataSet (набір взаємозв'язаних таблиць). Там визначені інтерфейси з'єднань з базами даних, команд, адаптерів даних.

System.Data.Common

Базові класи для всіх провайдерів даних DbConnection, DbCommand, DbDataAdapter.

System.Data.OleDb

Класи, що дозволяють працювати з джерелами даних OleDb, у тому числі з MS SQL версії 6.0 і нижче. Там знаходяться такі класи, як OleDbConnection, OleDbDataAdapter і OleDbCommand.

System.Data.SqlClient

Класи для MS SQL Server 7 і вище. Містить класи SqlConnection, SqlTransaction, SqlCommand і інші.

У складі Visual Studio 2008 є вбудований SQL Server 2005. Можна, також використовувати інші СКБД, такі як MS ACCESS, MySql, Oracle.

Працювати з базою даних можна з використанням візуальних засобів (майстрів) чи безпосередньо за допомогою програмування.

Далі ми розглянемо застосування технології на простих прикладах і почнемо з візуальних засобів роботи з ADO .Net.

Створимо базу даних LabDB і в ній таблицю Student.

8.2. Створення бази даних MS SQL Server в середовищі Visual Studio

Організація доступу до таблиць SQL EXPRESS візуальними засобами

1. Підключення до сервера БД

Головне меню View/Server Explorer відображає на екрані вікно серверів. Виділяємо вузол Data Connection, в контекстному меню вибираємо пункт Create New SQL Server Database (рис. 8.2).

Рис. 8.2. Підключення до сервера

Команди для візуальної роботи з різними джерелами даних зосереджені в меню Data.

2. Створення власної БД і таблиць

а) у вікні створення БД вибираємо сервер і вказуємо  назву БД: LabDB. У якості імені сервера вибираємо ім'я свого ПК і сервер SQLEXPRESS (рис. 8.3).

Використовуємо аутентифікацію Windows.

Рис. 8.3. Вибір сервера

б). В БД створюємо таблицю Student:

Для цього виділяємо вузол  Tables і вибираємо Add New Table (рис. 8.4).

Рис. 8.4. Створення таблиці в базі даних

В режимі конструктора створюємо потрібні поля, як показано на рис. 8.5. і зберігаємо таблицю під назвою Student.

Для введення даних у таблицю у вікні Server Explorer виділяємо вузол з назвою таблиці, в контекстному меню вибираємо Show Table Data.

Для зміни структури таблиці – вибираємо Open Table Definition.

Для внесення змін у таблицю на диску – вибираємо Refresh.

Для перегляду частини даних з таблиці за певним критерієм – вибираємо New Query.

Рис. 8.5. Контекстне меню для роботи з таблицею і структура створеної таблиці

Можна, також, користуватися меню Data (рис. 8.7).

Рис. 8.6. Меню додавання нової таблиці

3. Заповнення таблиці тестовими даними

Тепер, коли створена структура таблиці, в неї потрібно ввести деякі дані. Введемо дані про студентів у потрібні поля:

Student_ID  унікальний ідентифікатор студента (число);

St_Name – прізвище;

St_group – шифр групи;

St_rating – рейтинг (середній бал успішності).

Для введення даних у таблицю у вікні Server Explorer виділяємо вузол з назвою таблиці, з контекстного меню вибираємо Show Table Data. Вводимо дані. Даємо Refresh для фіксації змін у БД.

4. Створення Windows-застосунку (форми)

Тепер, коли  база даних і таблиця створені, заповнена деякими тестовими даними, можна створювати  програми для роботи з таблицею.

Перший приклад демонструє вибір з таблиці прізвищ студентів і відображення його у списку. Для цього:

a) Створюємо новий проект. Вибираємо тип Windows Form Application, В полі Name вказуємо назву проекту – WindowsFormLabDB.

б) Створюємо на формі список ListBox. В ньому будуть відображатися прізвища всіх студентів групи. Властивості Name призначаємо listStudents.

5. Зв'язування елементів форми з джерелом даних

а) Встановлюємо для списку джерело даних (властивість DataSource) (рис. 8.7).

Рис. 8.7. Зв'язування елементів форми з джерелом даних

З таблиці вибираємо тільки прізвище.

Завершуємо роботу майстра.

На формі в невидимій частині буде розміщено 3 компоненти: DataSet1, studentBindingSource, studentTableAdapter.

б) для відображення даних з таблиці у списку, властивості DisplayMember призначимо назву вибраного в набір поля (St_Name).

д) зберігаємо рішення і запускаємо на виконання без режиму відлагодження.

Рис. 8.8. Зв'язування списку з полем таблиці

Для перегляду джерела даних можна скористатися пунктом меню Data – ShowDataSource (рис. 8.9).

Рис. 8.9. Доступ до перегляду джерел даних з меню Data

7. Створення запитів до даних і їх відображення на формі у вигляді таблиці (Grid)

Для перегляду даних у вигляді таблиці можна скористатися компонентом  DataGridView.

Розмістимо на формі компонент типу DataGridView. У вікні задач DataGridView Tasks вибираємо AddProjectData Source...(рис. 8.10).

Рис. 8.10. Створення джерела даних для компонента DataGridView

Вибираємо нашу БД і всі поля з таблиці Student (рис. 8.11).

Рис. 8.11. Вибір полів з таблиці Student, які будуть виводитися в DataGridView

Збираємо Рішення і запускаємо на виконання. Як видно з рис. 8.12, у списку виводяться тільки прізвища, а в DataGridView всі поля.

Рис. 8.12. Результат роботи застосування

Змінимо заголовки колонок таблиці. Для цього виділимо DataGridView і під вікном властивостей виберемо посилання Edit Columns. У вікні Edit Columns по черзі вибираємо назви колонок і змінюємо для них властивості HeaderText.

Рис. 8.13. Зміна заголовків колонок в DataGridView

Висновки

Компонента модель ADO .Net розроблена для спрощення доступу до різних джерел даних з програм.  Ця модель містить дві групи об'єктів:

1. приєднані – які потребують постійного зв'язку з базой даних;

2. від'єднані – забезпечують роботу з даними в оперативній пам'яті програми.

Для роботи з базою даних в програмі можна використовувати візуальні засоби і готові компоненти, а також програмний код.

В цій лекції ми розглянули прості візуальні засоби створення і використання даних.

Для доступу і маніпулювання даними загалом потрібно виконати таку послідовність дій:

- створити базу даних і таблиці в ній, заповнити їх тестовими даними (чи реальними). Ця дія не залежить від програми і може пропускатися, якщо база даних вже існує;

- створити форму з елементами керування, в які вибрані дані будуть виводитися з бази даних;

- встановити з'єднання з базою даних;

- створити і заповнити даними об'єкт DataSet;

- зв'язати об'єкт DataSet з елементами форми (списком), вказавши його у якості джерела даних для властивості DataSource;

- призначити властивості DisplayMember назву вибраного в набір поля.

Візуальні засоби дозволяють дуже швидко створювати прості застосування без програмування. Особливо це корисно для розробки прототипу застосунку.

Контрольні запитання і завдання

1. Об'єкт класу DataSet є приєднаним чи від'єднаним?

2. Об'єкт класу Data Adapter є приєднаним чи від'єднаним?

3. Які компоненти ADO .Net забезпечують доступ до бази даних?

4. Що таке sqlDataAdapter? Які функції він реалізує?

5.Яке призначення класу DataSet? Яка його структура і призначення?

6. Від'єднані об'єкти моделі ADO .NET та їх призначення?

7. Основні приєднані об'єкти моделі ADO .NET та їх призначення?

8. Яка властивість списку ListBox визначає джерело даних?

9. Яка властивість списку ListBox дозволяє відобразити вибрані дані у вигляді списку?

10. Як вивести дані у вигляді таблиці за допомогою компонента DataGridView?


 

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

79196. Понятие и виды телесных повреждений 34.48 KB
  Понятие вред здоровью в уголовном законе не раскрывается. Определение вида вреда производилось в соответствии судебно медицинской экспертизой тяжести вреда здоровью на основании критериев указанных в постановлении Правительства РФ от 17 августа 2007 г. N 522 Об утверждении правил определения степени тяжести вреда здоровью человека . С медицинской точки зрения под вредом здоровью понимают нарушение анатомической целостности органов и тканей или их физиологических функций либо заболевания или патологические состояния возникшие в результате...
79197. Умышленное причинение тяжкого вреда здоровью. Состав и виды 34.79 KB
  Имеется в виду причинение вреда здоровью опасного для жизни человека который по своему характеру угрожает жизни потерпевшего и может вызвать его смерть. Причинение тяжкого вреда здоровью распространяется и на повреждения неопасные для жизни в момент их причинения но повлекшие угрожающие жизни состояния и заболевания или патологические состояния возникшие в результате воздействия различных внешних факторов и закономерно осложняющиеся угрожающим жизни состоянием или сами представляющие угрозу для жизни человека. В соответствии с...
79198. Заражение ВИЧ-инфекцией. Состав и виды 30.41 KB
  Способы совершения данного преступления различные: в результате полового контакта; при переливании крови или ее препаратов содержащих вирус; при контактах поврежденных поверхностей тела; при использовании для инъекций не стерильных шприцев а также женщинойвирусоносителем при родах либо с молоком матери зараженным вирусом и в других случаях. Состав преступления формальный для окончания преступления не требуется наступления последствий а именно заражения потерпевшего.
79199. Оставление в опасности 30.24 KB
  Преступление небольшой тяжести состав основной простой формальный Объект общественные отношения обеспечивающие безопасность жизни или здоровья Обязательный признак потерпевший другой человек находящийся в опасном для жизни или здоровья состоянии и лишенное возможности принять меры к самосохранению по малолетству старости болезни или вследствие своей беспомощности Объективная сторона характеризуется общественноопасным деянием в форме бездействия оставление без помощи вышеуказанного лица обстоятельства совершения...
79200. Общая характеристика преступлений против свободы, чести и достоинства личности 31.93 KB
  Отнесение рассматриваемой главы к разделу о преступлениях против личности которым открывается Особенная часть УК РФ вытекает из конституционных положений об охране свободы защите своей чести и доброго имени достоинства личности например ст. 126128 УК РФ; б честь и достоинство человека включая оценку его личности окружающими и им самим ст.
79201. Похищение человека. Состав и виды. Отличие от незаконного лишения свободы 34.79 KB
  Под похищением человека ст. Но при всех условиях похищение признается оконченным с момента захвата похищенного лица т. Наказание за похищение значительно усиливается при наличии квалифицирующих обстоятельств ч.
79202. Клевета. Состав и виды. Отличие от ложного доноса 34.68 KB
  С объективной стороны клевета определяется как распространение заведомо ложных сведений порочащих честь и достоинство другого лица или подрывающих его репутацию. Имеются в виду измышления заведомо ложные сведения подрывающие положительную оценку окружающими общественным мнением личности и его деятельности как не соответствующих этическим правовым профессиональным критериям. Обязательный элемент понятия клеветы распространение заведомо ложных сведений компрометирующих человека в устной или письменной форме в том числе в официальном...
79203. Общая характеристика преступлений против половой неприкосновенности и половой свободы личности 32.66 KB
  Разновидностью преступлений против личности являются общественно опасные посягательства на половую неприкосновенность и половую свободу человека. Видовым объектом преступлений являются общественные отношения обеспечивающие половую неприкосновенность и половую свободу личности. Непосредственным объектом выступают отношения связанные с посягательством на половую неприкосновенность и половую свободу конкретной личности нарушенные общественно опасным действием. Половые преступления в зависимости от непосредственного объекта можно подразделить...
79204. Изнасилование. Состав и виды 31.04 KB
  Беспомощное состояние потерпевшей при изнасиловании может выражаться в том что она: 1 не могла понимать характера и значения совершаемых действий в силу своего физического или психического состояния малолетства душевного расстройства беспамятства или иного болезненного состояния; 2 понимала характер совершаемых в отношении ее действий но не могла оказать сопротивления виновному физические недостатки сильное опьянение и т. Виновный же должен осознавать беспомощное состояние потерпевшей вне зависимости от того привел ли он сам...