17319

Компонентне програмування – робота з обєктами БД

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

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

Лабораторна робота 5 Компонентне програмування робота з об'єктами БД. Мета роботи: 1. Розробка інформаційної моделі схеми бази даних 2. Відображення даних із зв'язаних таблиць 1. Розробка інформаційної моделі схеми бази даних Розробка діаграми дозволяє візуа...

Украинкский

2013-06-30

1.17 MB

2 чел.

Лабораторна робота 5

Компонентне програмування – робота з об'єктами БД. 

Мета роботи:

1. Розробка інформаційної моделі (схеми бази даних)

2. Відображення даних із зв'язаних таблиць

1. Розробка інформаційної моделі (схеми бази даних)

Розробка діаграми дозволяє візуальними засобами встановити зв'язки між таблицями, а також створити самі таблиці.

Команди роботи з даними зосереджені в пункті меню Data головного меню Visual Studio.

Створення нової діаграми виконується у вікні ServerExplorer.  Для цього потрібно вибрати команду AddNewDiagram з контекстного меню, або відповідну команду з меню Data.

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

У вікні побудові діаграм над вибраною таблицею можна виконувати різні дії (видалити з діаграми, з бази даних, встановити зв'язки, тощо).

Встановлення зв'язків між таблицями (зовнішніх ключів).

Створену діаграму через  буфер обміну можна вставити в документацію на систему.

Схема БД DiplomMagistr

Як  видно з діаграми, таблиця Student  не використовується і її можна видалити. Прізвище студента вказується прямо в таблиці Diplom_Thema.

2. Відображення даних із зв'язаних таблиць

Створимо рішення типу Windows Application з назвою DiplomThemes. Розмістимо на формі об'єкт TabControl.  Через властивість TabPage об'єкту додамо ще одну закладку і призначимо назви закладкам.

На першій закладці розмістимо об'єкт  ComboBox, в який виведемо список груп з таблиці Group і об'єкт  dataGridView, в який будемо виводити теми робіт по кожній групі з таблиці Diplom_Thema. Такий спосіб відображення називають "майстер-деталь".

Для двох таблиць нам потрібно два провайдери (адаптери) даних  і два набори даних.  Розмістимо їх на формі  та зв'яжемо з потрібними таблицями в базі даних Diplom_Magistr.

Створення набору даних для першої таблиці

1. Розмістимо на формі sqlDataAdapter1

2. Виберемо базу даних, налаштуємо адаптер тільки на читання і перейдемо у вікно побудови запиту (кнопка QueryBuilder)

3. У вікна Add Table виберемо таблицю Group і натиснемо кнопку Add

 

4. Виберемо поле GroupID  задамо сортування в порядку збільшення.

5. Створимо набір даних DataSet1. Для цього виділимо адаптер sqlDataAdapter1 і командою з контекстного меню Data/Generate Dataset 

створимо для нього клас DataSet1 і об'єкт набору даних з ім'ям dataSet11.

Створення набору даних для другої таблиці

1. Розмістимо на формі sqlDataAdapter2

2. Виберемо базу даних і перейдемо у вікно побудови запиту (кнопка QueryBuilder)

3. У вікна Add Table виберемо таблицю Diplom_Thema  і натиснемо кнопку Add.  У вікні Query Builder налаштуємо Select  на передачу параметра по полю GroupID. Додамо таблицю professor  для вибору прізвища керівника роботи. У результаті буде згенеровано такий оператор Select:

4.Створимо новий набір даних DataSet21 для цього адаптера.

Розмістимо на формі об'єкт DataGrid

5. Зв'яжемо набір даних dataSet11 з ComboBox1, а dataSet21 з dataGridView1.

Для цього потрібно налаштувати їхні властивості DataSource .

Для об'єкту ComboBox1

 

Для dataGridView:

Створимо для форми Form1 обробник події Load, а для ComboBox - обробник події SelectedIndexChanged.

namespace DiplomThemes

{

   public partial class Form1 : Form

   {

       public Form1()

       {

           InitializeComponent();

       }

       private void Form1_Load(object sender, EventArgs e)

       {

           sqlDataAdapter1.Fill(dataSet11);

           RefreshTable();

       }

       private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)

       {

           // Заполнить dataSet21 и связанный с ним DataGrid данными связанной таблицы

 

           RefreshTable();

        }

       private void RefreshTable()

       {

           // Заполнить dataSet21 и связанный с ним DataGrid данными

           // таблицы Orders - Заказы для выбранного Заказчика

           dataSet21.Clear();

           // Если выбран Заказчик в ComboBox

           if (comboBox1.SelectedIndex != -1)

           {

               sqlDataAdapter2.SelectCommand.Parameters[0].Value =

                   comboBox1.SelectedValue;

              sqlDataAdapter2.Fill(dataSet21);

           }

       }

   }

}

Завдання для самостійного виконання:

1. Виконати приклад, наведений в цій роботі.

2. Реалізувати на закладці 2 можливість додавання нової теми.

3. Реалізувати на закладці 3 можливість  перегляду даних про керівників, видалення, оновлення та додавання керівників.

4. Реалізувати на закладці 4 можливість додавання, оновлення і видалення груп.

5. Для свого варіанту завдання (Лаб 2) додати  1 зв 'язану таблицю і реалізувати програму для роботи з даними.

Структура БД Diplom_Magistr

Diplom_Thema

Group

Kafedra

professor


 

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

53309. Україна в роки Другої світової війна (1939 -1945 рр.). Велика Вітчизняна війна (1941-1945 рр.) 131.5 KB
  Виховувати почуття гордості до історичного минулого України. Доповніть текст: Приєднання Західної України та Західної Білорусії до СРСР розпочалося після вступу Червоної армії на територію Польщі. Закон про включення Західної України до складу СРСР і воззєднання її з Українською РСР було прийнято: а Верховними Радами СРСР та УРСР у листопаді 1939 р.; б Народними зборами Західної України у жовтні 1939 р.
53310. Московська держава 74.5 KB
  МЕТА: Ознайомити учнів із внутрішній та зовнішній політикою Івана IV. Вінчання Івана IV на царство. Судебник Івана IV. ТИП УРОКУ: комбінований СТРУКТУРА УРОКУ Організаційний момент Актуалізація Вивчення нового матеріалу ІванIV Грозний; Реформи царя Івана IV; Опричнина та її наслідки для розвитку Росії; Зовнішня політика Івана IV.
53311. Двомовне вивчення історії у 5 класі як засіб формування громадянської свідомості учнів 56.5 KB
  Методи та прийоми: інформаційно-повідомлюючий пояснювально-спонукальний частково пошуковий; бесіда колективна та самостійна робота з підручником атласом; практичне завдання в контурній карті; інтерактивні вправи дидактичні ігри. В низинах Дніпра за дніпровськими порогами пролягали безкрайні...
53313. Козацька Україна 290 KB
  Рубрика Секрети старого козака. lмпровізована сцена біля дошки яка містить елементи відтворення української хати мальованого образу козака українського орнаменту та квітів. Виходять учень та учениця в українських костюмах: Ученькозак: В сивусиву давнину Козаки йшли на війну Бо на рідну Україну Сунулися без упину Ляхи турки та татари Москалі та яничари. Ученицякозачка: Козаки скликають раду: Не буде ворогу пощади Вірні коні рвуться в битву Крешуть іскри зпід копита.
53314. Використання НІТ в адміністративно-господарській діяльності школи 143 KB
  Впровадження НІТ в адміністративно-господарську діяльність школи Напрямки: Організаційне забезпечення. Розвиток єдиного інформаційного простору школи. функціонування інформаційноуправлінської господарської системи закладу; розробка методики використання НІТ в учбовому процесі; застосування різних форм мотивація вчителів працівників школи до використання НІТ в навчальновиховному процесі атестація матеріальне заохочення тощо.
53315. Хлеб - всему голова 41.5 KB
  Воспитывать любовь уважение и бережное отношение к труду и хлебу. Оборудование: Плакат Хлеб - всему голова колоски пшеницы иллюстрации к теме Ход 1. Ребята как вы думаете что это Хлеб.
53316. Хліб – годувальник, всьому голова 38.5 KB
  Мета: виховувати бережне ставлення до хліба повагу до хліборобів. Обладнання: у святковоприбраній світлиці на столі на вишитій скатертині скіп пшениці хлібина вироби з тіста. На землі вирощують хліб.