C#:SQLite数据库总是被锁定
发布时间:2020-12-15 17:16:26 所属栏目:百科 来源:网络整理
导读:我写了一个简单的应用程序(称之为app1),它读取SQLite数据库并在gridview中显示内容.我有一个单独的C#控制台应用程序(app2)需要写入同一个数据库.问题是app2因“数据库被锁定”错误而失败.我可以看到,一旦启动app1,就会创建一个userdb-journal文件.我假设问题
我写了一个简单的应用程序(称之为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可以读取和写入数据库? 编辑 编辑 解决方法
这是代码,在连接字符串构建器上轻松设置参数,并使用它构建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())) { //... } 问候. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |