我写了一个简单的应用程序(称之为app1),它读取SQLite数据库并在gridview中显示内容。我有一个单独的C#控制台应用程序(app2)需要写入同一个数据库。问题是app2因“数据库被锁定”错误而失败。我可以看到,一旦启动app1,就会创建一个userdb-journal文件。我假设问题是app1打开数据库但不释放它?这是我用来填充表I绑定到app1中的网格的代码。
public DataTable GetAllPeople()
{
var connectionString = "Data Source=" + dbPath + ";Version=3";
using (SQLiteDataAdapter sqlDataAdapter =
new SQLiteDataAdapter("SELECT id,FirstName,LastName,Address FROM Users",
connectionString))
{
using (DataTable dataTable = new DataTable())
{
sqlDataAdapter.Fill(dataTable);
// code to add some new columns here
return dataTable;
}
}
}
以下是填充gridview的代码:
private void Form1_Load(object sender, EventArgs e)
{
UserDatabase db = new UserDatabase();
db.Initialize();
dataGridView1.DataSource = db.GetAllPeople();
}
如何解决问题,以便在app1运行时app2可以读取和写入数据库?
修改 看起来该日志文件仅由app2创建。当app1也在运行时我才注意到数据库锁定错误,但也许app1是一个红色的鲱鱼。 App2是多线程的。也许我应该开始关注app2和多线程访问的新问题?
修改 感谢所有的评论。我已经锁定所有数据库访问并将所有内容包装在使用中。现在一切似乎都在起作用。
答案 0 :(得分:2)
以下是代码,在连接字符串构建器上轻松设置参数,并使用它构建SQLiteConnection。
SQLiteConnectionStringBuilder connBuilder = new SQLiteConnectionStringBuilder();
connBuilder.DataSource = filePath;
connBuilder.Version = 3;
connBuilder.CacheSize = 4000;
connBuilder.DefaultTimeout = 100;
connBuilder.Password = "mypass";
using(SQLiteConnection conn = new SQLiteConnection(connBuilder.ToString()))
{
//...
}
问候。
答案 1 :(得分:0)
您是否曾要求SQLITE等待,如果数据库被锁定,请再试一次?以下是如何在C
中完成的 // set SQLite to wait and retry for up to 100ms if database locked
sqlite3_busy_timeout( db, 100 );
重点是SQLITE在访问数据库时会短暂锁定数据库。如果另一个线程或进程在被阻止时访问它,则SQLITE默认返回错误。但是你可以让它等待,并通过上述调用自动重试。这解决了许多这类问题。