Есть ли способ подключить MSSQL-сервер к .NET CORE (2.2) API без использования EF? - PullRequest
0 голосов
/ 21 февраля 2019

Я новичок в .Net Core. На данный момент я пытаюсь подключить существующую базу данных в MSSQL Server из .Net Core API.

Но все примеры, которые я нашел, использует EF.

Но я хочу подключить сервер MSSQL из пользовательского класса следующим образом.

DataBaseConnection.cs

 public class DatabaseConnection 
    {
        private SqlDataAdapter sqlAdapter;
        private SqlConnection sqlConnection;
        SqlCommand sqlCommand = new SqlCommand();

        // Initialise Connection

        public DatabaseConnection()
        {
            sqlAdapter = new SqlDataAdapter();
            sqlConnection = new SqlConnection(ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString);
        }

        // Open Database Connection if Closed or Broken

        private SqlConnection openConnection()
        {
            if (sqlConnection.State == ConnectionState.Closed || sqlConnection.State == ConnectionState.Broken)
            {
                sqlConnection.Open();
            }
            return sqlConnection;
        }
}

Внутри конструктора я получил ошибкуas

enter image description here

appsettings.json

{
  "ConnectionStrings": {
    "DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=HealthAPI;Trusted_Connection=True;MultipleActiveResultSets=true"
  },
  "Logging": {
    "LogLevel": {
      "Default": "Warning"
    }
  },
  "AllowedHosts": "*"
}

Есть ли возможность установить соединение с базой данных без использования EF?

Ответы [ 2 ]

0 голосов
/ 21 февраля 2019

Используйте это так

Configuration.GetSection("ConnectionStrings").DefaultConnection
0 голосов
/ 21 февраля 2019

Я сделал это, используя обходной путь.Ниже приведен код.

public abstract class BaseDataService
{
    private Database database = null;

    public BaseDataService()
    {
        DatabaseFactory.SetDatabaseProviderFactory(new DatabaseProviderFactory(new SystemConfigurationSource(false).GetSection), false);
        this.database = DatabaseFactory.CreateDatabase("_connection");
    }
    public Database SqlDatabase
    {
        get
        {
            return this.database;
        }

        set
        {
            this.database = value;
        }
    }
}

Файл App.config

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="system.data" type="System.Data.Common.DbProviderFactoriesConfigurationHandler, Microsoft.Practices.EnterpriseLibrary.Data, Version=6.0.0.0, Culture=neutral, PublicKeyToken=null"/>
  </configSections>

  <connectionStrings>
    <add name="_connection" connectionString="Server=localhost;Database=DBNAME;Trusted_Connection=True;" providerName="System.Data.SqlClient"  />
  </connectionStrings>
</configuration>

Использование

public class MyDataService : BaseDataService
{
    public IList<Test> ReadTest()
    {
        IList<Test> testList = new List<Test>();
        DbCommand selectCommand = null;

        selectCommand = SqlDatabase.GetStoredProcCommand("[dbo].[CSP_Test_SelectAll]");

        using (DataSet result = SqlDatabase.ExecuteDataSet(selectCommand))
        {
            if (result.Tables[0].Rows.Count > 0)
            {
                DataTable dataTable = result.Tables[0];
                feesList = dataTable.ConvertTo<Test>();
            }
        }

        return testList;
    }
}

Необходимые пакеты

<PackageReference Include="EnterpriseLibrary.Data.NetCore" Version="6.0.1313" />

Редактировать:

Я просмотрел ваш код, и проблема в получении значений конфигурации

public DatabaseConnection(IConfiguration configuration)
{
      string connectionString = configuration.GetConnectionString("DefaultConnection");
      sqlAdapter = new SqlDataAdapter();
      sqlConnection = new SqlConnection(connectionString);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...