Ошибка при попытке подключиться к базе данных доступа в C# для проекта

Я пытаюсь создать проект, который будет читать, писать и проверять наличие дубликатов в моем файле базы данных доступа. Я использую C# и получаю сообщение об ошибке "Ошибка подключения", которое я записал в программу, если состояние подключения = 0. Если кто-то может предложить какую-либо помощь, я был бы признателен. Я использую Access 2016 и не уверен, какие ссылки мне нужны для моего проекта (если есть). Все, что я нашел в Интернете, устарело или не работает.

Спасибо!

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Threading;
using System.Net;
using System.IO;
using System.Data.OleDb;


 namespace RHG
{

public partial class Form1 : Form
{

    public Form1()
    {
        InitializeComponent();
    }

    private void Form1_Load(object sender, EventArgs e)
    {

        using (OleDbConnection connection = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.16.0;Data Source=C:\Users\grosales\Documents\rhg\RHG\Used.accdb"))
        {
            try
            {
                connection.Open();
                MessageBox.Show("connected");
            }
            catch (Exception ex)
            {
                MessageBox.Show("connection failed");
            }
        }

    }

`

2 ответа

Решение

Вы не открыли соединение.

connection.Open();

Примечание. Проверка состояния соединения недостаточна. Вы можете получить исключение при попытке открыть соединение. Вместо этого приложите это в try-catch.

Рекомендуется также включать работу в связи с using

using (var connection = new OleDbConnection()) {
    connection.ConnectionString =
        @"Provider=Microsoft.ACE.OLEDB.16.0;Data Source=C:\Users\...\Used.accdb";
    try {
        connection.Open();

        //TODO: do something with the connection

    } catch (Exception ex) {
        MessageBox.Show("Connection Failed\r\n\r\n" + ex.Message);
    }
}

Это гарантирует, что соединение будет закрыто и ресурсы будут освобождены.

Попробуйте следующие примеры: https://msdn.microsoft.com/en-us/library/system.data.oledb.oledbconnection(v=vs.110).aspx

Вы пропускаете соединение.Open(); заявление, которое должно быть завернуто в попытку поймать.

Кроме того, вы можете указать строку подключения в конструкторе, например

using (OleDbConnection connection = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.16.0;Data Source=C:\Users\grosales\Documents\rhg\RHG\Used.accdb")) 
{
    //do DB access here
}
//no need to call connection.Close() - it's automatically done once you leave the using block.
Другие вопросы по тегам