Пошаговое руководство. Создание классов LINQ to SQL с помощью наследования одной таблицы (конструктор O/R)
Средства LINQ to SQL в Visual Studio поддерживают одно табличное наследование, так как оно обычно реализуется в реляционных системах. В этом пошаговом руководстве рассматриваются общие действия, описанные в разделе "Практическое руководство. Настройка наследования с помощью раздела конструктора O/R" и предоставление некоторых реальных данных для демонстрации использования наследования в конструкторе O/R.
В этом пошаговом руководстве выполняются следующие задачи:
Создайте таблицу базы данных и добавьте в нее данные.
Создайте приложение Windows Forms.
Добавьте в проект LINQ to SQL-файл.
Создайте новые классы сущностей.
Конфигурируйте классы сущностей на использование наследования.
Выполните запрос унаследованного класса.
Отобразите данные на Windows Forms
Создание таблицы для наследования
Чтобы узнать, как работает наследование, создайте небольшую Person
таблицу, используйте ее в качестве базового класса, а затем создадите объект, наследуемый Employee
от него.
Для создания базовой таблицы, чтобы продемонстрировать наследование
В обозревателе серверов или обозревателе баз данных щелкните правой кнопкой мыши узел таблиц и нажмите кнопку "Добавить новую таблицу".
Примечание.
Может быть использована база данных Northwind или любая другая, к которой можно добавить таблицу.
В Конструкторе таблиц добавьте в таблицу следующие столбцы:
Имя столбца Тип данных Разрешить значения NULL ИД int False Тип int True FirstName nvarchar(200) False LastName nvarchar(200) False Менеджер int True Задайте столбец ID в качестве первичного ключа
Сохраните таблицу и дайте ей имя Person.
Добавление данных в таблицу
Чтобы вы могли убедиться, что наследование конфигурировано правильно, в таблицу нужно ввести некоторые данные для каждого класса в наследовании единственной таблицы.
Для добавления данных в таблицу
Откройте таблицу в окне просмотра данных. (Щелкните правой кнопкой мышиТаблица person в обозревателе сервера или обозревателе баз данных и нажмите кнопку "Показать данные таблицы".)
Скопируйте в таблицу следующие данные. (Его можно скопировать, а затем вставить в таблицу, выбрав всю строку в списке Область результатов .)
ИД Тип FirstName LastName Менеджер 1 1 Anne Wallace NULL 2 1 Carlos Grilo NULL 3 1 Yael Peled NULL 4 2 Gatis Ozolins 1 5 2 Andreas Hauser 1 6 2 Tiffany Phuvasate 1 7 2 Alexey Orekhov 2 8 2 Michał Poliszkiewicz 2 9 2 Tai Yee 2 10 2 Fabricio Noriega 3 11 2 Mindy Martin 3 12 2 Ken Kwok 3
Создание нового проекта
Теперь, когда таблица создана, создайте новый проект, чтобы продемонстрировать настройку наследования.
Создание нового приложения Windows Forms
В Visual Studio в меню Файл выберите пункты Создать>Проект.
Разверните Visual C# или Visual Basic в левой области, а затем выберите "Рабочий стол Windows".
В средней области выберите тип проекта приложения Windows Forms.
Назовите проект InheritanceWalkthrough и нажмите кнопку "ОК".
Создается проект InheritanceWalkthrough и добавляется в Обозреватель решений.
Добавление в проект файла классов LINQ to SQL
Для добавления файла LINQ to SQL в проект
В меню Проект выберите Добавить новый элемент.
Щелкните шаблон классов LINQ to SQL, а затем нажмите кнопку "Добавить".
Файл
.dbml
добавляется в проект и откроется конструктор операций ввода-вывода .
Создание наследования с использованием реляционного конструктора объектов
Настройте наследование путем перетаскивания объекта Наследование из Панели элементов на область конструктора.
Чтобы создать наследование, выполните следующие действия
В обозревателе серверов или обозревателе баз данных перейдите к созданной ранее таблице Person.
Перетащите таблицу Person в область конструктора O/R Designer .
Перетащите вторую таблицу Person в конструктор O/R и измените его имя на Employee.
Удалите свойство Manager из объекта Person.
Удалите свойства Type, ID, FirstName и LastName из объекта Employee. (Другими словами, удалите все свойства, кроме свойства Manager.)
Из вкладки Реляционный конструктор объектовПанели элементов создайте Наследование между объектами Person и Employee. Чтобы выполнить это, щелкните по пункту Наследование в Панели элементов и отпустите кнопку мыши. Затем щелкните объект Employee и объект Person в конструкторе O/R. Стрелка на линии наследования указывает на объект Person .
Щелкните по линии Наследование на области конструктора.
Задайте свойству Свойство дискриминатора значение Type.
Задайте свойству Производное значение дискриминатора класса значение 2.
Задайте свойству Базовое значение дискриминатора класса значение 1.
Задайте свойству Наследование по умолчанию значение Person.
Выполните сборку проекта.
Выполнение запроса наследуемого класса и отображение данных на форме
Теперь вы добавите код в форму, которая запрашивает определенный класс в объектной модели.
Для создания запроса LINQ и отображения результатов на форме
Перетащите ListBox на форму Form1.
Дважды щелкните форму, чтобы создать обработчик событий
Form1_Load
.Добавьте следующий код в обработчик событий
Form1_Load
.
Тестирование приложения
Запустите приложение и убедитесь, что записи, отображенные в списке, представляют всех работников (записи, которые имеют значение 2 в столбце Type).
Тестирование приложения
Нажмите клавишу F5.
Убедитесь, что отображаются только записи со значением 2 в их столбце Type.
Закройте форму. (В меню Отладка щелкните пункт Остановить отладку.)
Связанный контент
- Средства LINQ to SQL в Visual Studio
- Пошаговое руководство. Создание классов LINQ to SQL (реляционный конструктор объектов)
- Практическое руководство. Назначение хранимых процедур для выполнения обновления, вставки и удаления (реляционный конструктор объектов)
- LINQ to SQL
- Практическое руководство. Создание модели объектов в Visual Basic или C#