C# 如何防止Sqlite数据库被锁定?

C# 如何防止Sqlite数据库被锁定?,c#,sqlite,C#,Sqlite,我在数据库里找到了一条线索。当我点击菜单时,它会显示一个错误“数据库被锁定”,而且这只是偶尔发生的。有没有办法防止数据库锁定?我试过了,但不起作用 阅读: private void checkPort(string ipIN, char[] input, string output) { try { bool building = false; Thread beep = new Thread(Beep);

我在数据库里找到了一条线索。当我点击菜单时,它会显示一个错误“数据库被锁定”,而且这只是偶尔发生的。有没有办法防止数据库锁定?我试过了,但不起作用

阅读:

private void checkPort(string ipIN, char[] input, string output)
    {
        try
        {
            bool building = false;
            Thread beep = new Thread(Beep);
            using (SQLiteConnection c = new SQLiteConnection(dbconnection))
            {
                c.Open();
                string query = "select * from ALL_IO(nolock)";
                using (SQLiteCommand cmd = new SQLiteCommand(query, c))
                {
                    using (SQLiteDataReader dr = cmd.ExecuteReader())
                    {
                        int Contact;
                        while (dr.Read())
                        {
                            string _IP = dr.GetString(0);
                            string _IO_I = dr.GetString(1);
                            string _BuildingName = dr.GetString(4);
                            int IO_I = Convert.ToInt32(dr.GetString(1).Replace("DI ", ""));
                            if (dr.GetString(3) == "NC")
                            {
                                Contact = 1;
                            }
                            else
                            {
                                Contact = 0;
                            }
                            _tableName = dr.GetString(8);
                            string _name = dr.GetString(5);
                            var _active = dr.GetString(6);
                            var _status = dr.GetString(7);
                            if (_active == "Yes" && _status == "Enable")
                            {
                                 //Some condition check here
                            }

        }
        catch { }
    }
写作:

void contexMenuuu_ItemClicked(object sender, ToolStripItemClickedEventArgs e)
    {
        data = "";
        ToolStripItem item = e.ClickedItem;
        using (SQLiteConnection c = new SQLiteConnection(dbconnection))
        {
            c.Open();
            string sql = "select * from " + Properties.Settings.Default.TableName + "(nolock) where Name= '" + Properties.Settings.Default.LabelName.Replace(" DO", "") + "' ";
            using (SQLiteCommand cmd = new SQLiteCommand(sql, c))
            {
                using (SQLiteDataReader dr = cmd.ExecuteReader())
                {
                    while (dr.Read())
                    {
                        _controllerIP = dr.GetString(0);
                        _IO = dr.GetString(1);
                        _IO_O = dr.GetString(2).Replace("DO ", "");
                        _Name = dr.GetString(4);
                        _Interval = Convert.ToInt32(dr.GetString(9));
                    }
                }
            }
        }
        if (item.Text == "Bypass Enable")
        {
            using (SQLiteConnection c = new SQLiteConnection(dbconnection))
            {
                //c.DefaultTimeout = 2000;
                c.Open();
                string sql = "update ALL_IO SET Active='Yes', Status='Bypass' where ControllerIP='" + _controllerIP + "' and DI='" + _IO + "';";
                using (SQLiteCommand cmd = new SQLiteCommand(sql, c))
                {
                    lock (lockobj)
                    {
                        //SQLiteConnection.ClearAllPools();
                        cmd.ExecuteNonQuery(); //Error occur here
                    }                     
                }

            }

        }

功能完成后,必须关闭数据库连接以避免数据库锁定问题。为了执行查询,您打开了数据库连接,但没有关闭它。因此,您需要关闭。

我以前在iOS中遇到过相同的问题,我关闭了数据库连接,但之后它没有发生。如果我使用的是如上所述的函数show。我还用close吗?因为锁定只发生在某个时间,但总是发生在某个时间