Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
На нашем сайте KnigaRead.com Вы можете абсолютно бесплатно читать книгу онлайн Троелсен Эндрю, "Язык программирования C#9 и платформа .NET5" бесплатно, без регистрации.
// Для localdb используйте @"Driver={ODBC Driver 17 for SQL Server}; Server=(localdb)mssqllocaldb;Database=AutoLot;Trusted_Connection=Yes"; "ConnectionString": "Driver={ODBC Driver 17 for SQL Server}; Server=localhost,5433; Database=AutoLot;UId=sa;Pwd=P@ssw0rd;" }, "OleDb": { // Для localdb используйте @"Provider=SQLNCLI11; // Data Source=(localdb)mssqllocaldb;Initial Catalog=AutoLot;Integrated Security=SSPI"), "ConnectionString": "Provider=SQLNCLI11;Data Source=.,5433; User Id=sa;Password=P@ssw0rd; Initial Catalog=AutoLot;" }}Сообщите MSBuild о необходимости копировать файл JSON в выходной каталог при каждой компиляции. Модифицируйте файл проекта, как показано ниже:
<ItemGroup> <None Update="appsettings.json"><b> <CopyToOutputDirectory>Always</CopyToOutputDirectory></b> </None></ItemGroup>На заметку! Элемент
CopyToOutputDirectoryAlwaysТеперь, располагая подходящим файлом
appsettings.jsonproviderconnectionstringusingProgram.csusing System;using System.Data.Common;using System.Data.Odbc;#if PC using System.Data.OleDb;#endifusing System.IO;using Microsoft.Data.SqlClient;using Microsoft.Extensions.Configuration;Очистите весь код в
Program.csusing System;using System.Data.Common;using System.Data.Odbc;#if PC using System.Data.OleDb;#endifusing System.IO;using Microsoft.Data.SqlClient;using Microsoft.Extensions.Configuration;using DataProviderFactory;Console.WriteLine("***** Fun with Data Provider Factories *****n");var (provider, connectionString) = GetProviderFromConfiguration();DbProviderFactory factory = GetDbProviderFactory(provider);// Теперь получить объект подключения.using (DbConnection connection = factory.CreateConnection()){ if (connection == null) { Console.WriteLine($"Unable to create the connection object"); // He удалось создать объект подключения return; } Console.WriteLine($"Your connection object is a: {connection.GetType().Name}"); connection.ConnectionString = connectionString; connection.Open(); // Создать объект команды. DbCommand command = factory.CreateCommand(); if (command == null) { Console.WriteLine($"Unable to create the command object"); // He удалось создать объект команды return; } Console.WriteLine($"Your command object is a: {command.GetType().Name}"); command.Connection = connection; command.CommandText = "Select i.Id, m.Name From Inventory i inner join Makes m on m.Id = i.MakeId "; // Вывести данные с помощью объекта чтения данных. using (DbDataReader dataReader = command.ExecuteReader()) { Console.WriteLine($"Your data reader object is a: {dataReader.GetType().Name}"); Console.WriteLine("n***** Current Inventory *****"); while (dataReader.Read()) { Console.WriteLine($"-> Car #{dataReader["Id"]} is a {dataReader["Name"]}."); }