为了账号安全,请及时绑定邮箱和手机立即绑定

C# 数据库 SQLite 锁定数据库错误

C# 数据库 SQLite 锁定数据库错误

C#
白猪掌柜的 2021-06-04 14:13:05
我目前正在使用 C# 和 SQLite 编写代码。有一个错误正在抛出,指出数据库在消息框中被锁定两次。该查询适用于 SQLite DB 浏览器,但是,当它被放置在 C# 代码中时,它会引发错误。这是给我一个错误的代码:cmd.CommandText = "UPDATE customers SET Bill = Bill - "+textBox2.Text+" WHERE customers.CustomerID = " + textBox1.Text + ";";等号似乎有问题,算术过程可能有问题。完整代码: SQLiteConnection myconn = new SQLiteConnection(@"Data Source = C:\Users\chick\Newspaper.db");        SQLiteCommand cmd = myconn.CreateCommand();        cmd.CommandText = "UPDATE customers SET Bill = (Bill - "+textBox2.Text+") WHERE customers.CustomerID = " + textBox1.Text + ";";        myconn.Open();        try        {            cmd.ExecuteNonQuery();            MessageBox.Show("Succesfully Update");        }        catch(Exception ex)        {            MessageBox.Show(ex.Message);        }更新:将格式更改为using() {}但它仍然无法正常工作。程序崩溃新代码:   using (SQLiteConnection myconn = new SQLiteConnection(@"Data Source = C:\Users\chick\Newspaper.db"))        {            var sql = "Update customers SET Bill = Bill - @pay WHERE customers.CustomerID = @cid;";            myconn.Open();            using (var cmd = new SQLiteCommand(sql, myconn))            {                cmd.Parameters.AddWithValue("@cid", textBox1.Text);                cmd.Parameters.AddWithValue("@pay", textBox2.Text);                cmd.ExecuteNonQuery();            }        }
查看完整描述

2 回答

?
撒科打诨

TA贡献1934条经验 获得超2个赞

问题是程序的其他部分(或其他程序)仍然有活动事务。

您必须正确清理所有访问数据库的命令,即using在任何地方使用。


查看完整回答
反对 回复 2021-06-05
?
三国纷争

TA贡献1804条经验 获得超7个赞

感谢所有已经回答的人。我们意识到问题在于我们从未在之前的代码中关闭阅读器。


查看完整回答
反对 回复 2021-06-05
  • 2 回答
  • 0 关注
  • 255 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信