C#Windows应用程序访问数据库数据不会在关闭时持续存在

艾伦

我正在使用C#创建Windows应用程序,由此访问了一个空的Access数据库,该数据库包含两个表:Provinces和Locations。我正在处理只处理Provinces表的表单,如下所示:

在此处输入图片说明

这是一个子窗体。当它打开时,我可以插入/更新记录等。每当进行更改时,我都单击“加载表”按钮以在DataGridView对象中显示更改。

如果关闭此子窗体并再次显示它,则可以单击“加载表”按钮,然后调出所有数据以显示在DataGridView对象中。但是,如果我完全关闭该应用程序,那么我将丢失所有数据。我通过双击数据库文件以在Access中启动它来证明这一点,在那里我可以看到数据肯定消失了。因为我不知道为什么数据不能持久保存在文件中,所以这已经成为一个谜。请指教。

下面是表格的代码。您可以从我的方法中看到,每次执行函数时,我都会关闭连接对象。所以我茫然为什么我在应用程序关闭时总是丢失数据?

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

namespace GTI_Taxi_Pricing
{
public partial class frmProv : Form
{
    private OleDbConnection connection = new OleDbConnection();
    public frmProv()
    {
        InitializeComponent();
        connection.ConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=TaxiDB.accdb;Persist Security Info=False;";                
    }

    private void btnLoad_Click(object sender, EventArgs e)
    {
        try
        {
            connection.Open();
            OleDbCommand command = new OleDbCommand();
            command.Connection = connection;
            String query = "SELECT * FROM Provinces;";
            command.CommandText = query;
            OleDbDataAdapter da = new OleDbDataAdapter(command);
            DataTable dt = new DataTable();
            da.Fill(dt);
            dataGridView1.DataSource = dt;
            connection.Close();
        }
        catch(Exception ex)
        {
            MessageBox.Show("Error: " + ex);
        }
    }

    private void btnSave_Click(object sender, EventArgs e)
    {
        if (txtName.Text == "")
        {
            MessageBox.Show("The name field must have a value.");
            return;
        }
        try
        {
            connection.Open();
            OleDbCommand command = new OleDbCommand();
            command.Connection = connection;
            command.CommandText = "INSERT INTO Provinces (name) VALUES ('" + txtName.Text + "')";

            command.ExecuteNonQuery();
            MessageBox.Show("Data Saved");
            connection.Close();
        }
        catch(Exception ex)
        {
            MessageBox.Show("Error: " + ex);
        }
    }

    private void btnNewRecord_Click(object sender, EventArgs e)
    {
        txtID.Text = "";
        txtName.Text = "";
    }

    private void btnEdit_Click(object sender, EventArgs e)
    {
        if (txtID.Text == "")
        {
            MessageBox.Show("The id field must have a value.");
            return;
        }
        if(txtName.Text == "")
        {
            MessageBox.Show("The name field must have a value.");
            return;
        }
        try
        {
            connection.Open();
            OleDbCommand command = new OleDbCommand();
            command.Connection = connection;
            command.CommandText = "UPDATE Provinces SET name='" + txtName.Text + "' WHERE id=" + txtID.Text + ";";

            command.ExecuteNonQuery();
            MessageBox.Show("Data Update Successful.");
            connection.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show("Error: " + ex);
        }
    }

    private void btnDelete_Click(object sender, EventArgs e)
    {
        if (txtID.Text == "")
        {
            MessageBox.Show("The id field must have a value.");
            return;
        }
        try
        {
            connection.Open();
            OleDbCommand command = new OleDbCommand();
            command.Connection = connection;
            command.CommandText = "DELETE FROM Provinces WHERE id=" + txtID.Text + ";";

            command.ExecuteNonQuery();
            MessageBox.Show("Record Deleted Successfully.");
            connection.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show("Error: " + ex);
        }
    }

    private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
    {
        if(e.RowIndex >= 0)
        {
            DataGridViewRow row = dataGridView1.Rows[e.RowIndex];
            txtID.Text = row.Cells[0].Value.ToString();
            txtName.Text = row.Cells[1].Value.ToString();
        }
    }
}

}

史蒂夫

这是基于文件的数据库(或附加的数据库文件)的常见方案。
您的连接字符串引用数据库而不使用任何路径。
这意味着您的数据库位于应用程序运行所在的目录中。
在插入,修改或删除数据时没有任何问题,但是当您从INSIDE的Visual Studio调试会话中重新启动应用程序时,就失去了所有东西。

现在,如果查看项目文件,则可能在其他文件之间列出了数据库文件。在该数据库文件的属性之间,您会注意到该属性Copy to the Output directory及其设置为的值Copy Always

这意味着每次从Visual Studio环境中重新启动应用程序时,该文件都会从项目文件夹复制到输出目录(通常是BIN \ DEBUG或BIN \ x86 \ DEBUG),但这会破坏上一次运行删除中使用的数据库插入的数据已修改或删除

将该属性更改Copy to Output DirectoryCopy NeverCopy if Newer

但是Copy If Newer,MS-Access带来了另一个问题。如果使用Access o在Visual Studio的“服务器连接”窗口中使用Access o打开位于项目目录中的数据库文件,则即使不进行任何更改,该文件也会立即被修改,因此“如果更新则复制”将执行复制到输出目录的操作

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

Azure不会在EFCore 2应用程序发布时创建数据库架构

Flask 会话 cookie 不会在浏览器关闭时持续存在

无法在C#Windows应用程序的数据库中保存组合框选择的索引

如何在C#Windows应用程序中将记录从数据gridview条目插入SQL数据库?

应用程序不会在recyclerview火力显示数据

应用内购买不会在应用安装之间持续存在

访问数据库时应用程序崩溃

快速会话不会在页面之间持续存在

Sudo不会在Debian 10上持续存在

替换的HTML不会在DOM中持续存在

持续存在“从数据库读取错误”错误

从C#Windows应用程序表格中记录时间/日期是否已插入到Access数据库中?

我了解如何使用C#Windows Form应用程序连接Web mysql数据库

如何通过C#Windows应用程序连接查询并将查询发送到MariaDB数据库?

如何使用C#Windows Form应用程序将Excel文件上传到SQL数据库表

Vue.js + PHP Select输入不会在提交时持续存在

添加Woocommerce购物车费用不会在结帐时持续存在

React-query 缓存不会在页面刷新时持续存在

Windows窗体设置值不会在会话之间持续存在

.NET Framework 4 - 对数据库的第一次实体框架调用永远不会在控制台应用程序中完成

带有 EF6 的 WPF 应用程序不会在 SQL Server Enterprise 中创建新数据库

具有多个数据库上下文的.NET Core应用程序不会在所有DbContext中生成表

我应该在哪里正确放置sqlite数据库,这样它就不会在appstore的应用程序更新中被删除?

在我关闭我的应用程序并再次打开之前,数据不会在Firebase上添加

应用程序卸载Flutter时不会删除应用程序数据库

数据不会在数据库中更新

访问VBA应用程序。退出关闭多个数据库

Quartz 调度程序不会在 AWS RDS 故障转移时更新数据库连接

表格不会在数据库中提交