Практическое руководство. Сортировка коллекции с помощью LINQ (Visual Basic)
Обновлен: Ноябрь 2007
Запросы, интегрированные в язык программирования (Language-Integrated Query, LINQ), упрощают доступ к содержимому базы данных и обеспечивают выполнение запросов.
В приведенном ниже примере показано, как создать новое приложение, в котором выполняются запросы к базе данных SQL Server и сортируются результаты по множеству полей с помощью ключевого слова Order By. Порядок сортировки для каждого поля может быть возрастающим или убывающим. Дополнительные сведения см. в разделе Предложение Order By (Visual Basic).
В примерах этого раздела используется учебная база данных "Борей". Если учебная база данных "Борей" отсутствует на компьютере разработчика, ее можно загрузить с веб-узла центра загрузки Майкрософт. Инструкции см. в разделе Загрузка образцов баз данных (LINQ to SQL).
Примечание. |
---|
На вашем компьютере названия некоторых элементов интерфейса пользователя Visual Studio или их расположение могут отличаться от указанных в нижеследующих инструкциях. Это зависит от имеющегося выпуска Visual Studio и используемых параметров. Дополнительные сведения см. в разделе Параметры Visual Studio. |
Создание подключения к базе данных
В Visual Studio откройте Обозреватель серверов или Обозреватель баз данных; для этого в меню Вид щелкните Обозреватель серверов или Обозреватель баз данных.
В представлении Обозреватель серверов или Обозреватель баз данных щелкните правой кнопкой мыши Подключения данных, а затем щелкните Добавить подключение.
Укажите допустимое подключение к учебной базе данных "Борей".
Добавление в файл SQL проекта, содержащего LINQ
В Visual Studio, в меню Файл, наведите указатель на пунктНовый и щелкните Проект. Выберите Приложение Windows Forms в качестве типа проекта Visual Basic.
В меню Проект выберите команду Добавить новый элемент. Выберите шаблон элемента Классы LINQ-SQL.
Назовите файл northwind.dbml. Нажмите кнопку Добавить. Открывается реляционный конструктор объектов для файла northwind.dbml.
Добавление таблицы к запросу в реляционном конструкторе объектов
В представлении Обозреватель серверов или Обозреватель баз данных разверните подключение к базе данных "Борей". Разверните папку Таблицы.
Если реляционный конструктор объектов закрыт, откройте его снова, дважды щелкнув файл northwind.dbml, добавленный ранее.
Щелкните таблицу "Клиенты" и перетащите ее в левую область конструктора. Щелкните таблицу "Заказы" и перетащите ее в левую область конструктора.
В конструкторе создаются новые объекты Customer и Order для проекта. Обратите внимание, что конструктор автоматически обнаруживает связи между таблицами и создает дочерние свойства для связанных объектов. Например, функция IntelliSense покажет, что в объекте Customer имеется свойство Orders для всех заказов, связанных с клиентом.
Сохраните изменения и закройте конструктор.
Сохраните проект.
Добавления кода в запрос к базе данных и отображение результатов
Из панели инструментов перетащите элемент управления DataGridView в заданную по умолчанию форму Windows для проекта (Form1).
Дважды щелкните Form1, чтобы добавить код в событие Load формы.
При добавлении таблиц в реляционный конструктор объектов конструктор добавил объект DataContext в проект. Этот объект содержит код, необходимый для доступа к этим таблицам и доступа к отдельным объектам и коллекциям для каждой таблицы. Объекту DataContext для проекта присвоено имя на основе имени файла .dbml. Для данного проекта объект DataContext называется northwindDataContext.
Можно создать экземпляр DataContext в коде и запросить таблицы, указанные реляционным конструктором объектов.
Добавьте приведенный ниже код к событию Load, чтобы выполнить запрос к таблицам, которые представлены в виде свойств контекста данных, и отсортировать результаты. В запросе результаты сортируются по числу заказов клиентов в порядке убывания. Клиенты, имеющие одинаковое количество заказов, упорядочены по названию компании в возрастающем порядке (по умолчанию).
Dim db As New northwindDataContext Dim q = From cust In db.Customers _ Where cust.Orders.Count > 0 _ Select cust.CustomerID, cust.CompanyName, _ OrderCount = cust.Orders.Count, cust.Country _ Order By OrderCount Descending, CompanyName DataGridView1.DataSource = q
Нажмите клавишу F5, чтобы запустить проект и просмотреть результаты.
См. также
Задачи
Пошаговое руководство. Создание классов LINQ to SQL (реляционный конструктор объектов)
Основные понятия
Методы DataContext (реляционный конструктор объектов)