SQLite连接问题

时间:2014-02-12 23:22:10

标签: sqlite devart dotconnect

在尝试在我的开发机器以外的机器上测试项目时,我遇到了最奇怪的行为。在开发机器上一切正常,但在部署程序时,我收到“打开DbConnection时出错”。使用InnerException“无法打开数据库文件。”

基本上,我在exe文件所在的文件夹中有一个空的数据库(只有架构),就像我说的那样,在开发机器上一切正常。我正在使用LinqConnect来查询SQLite数据库。以下是出现错误的方法(对于访问数据库的任何方法也会收到相同的错误)。

private void LoadAccountsFromDatabase()
{
    var accounts = new ObservableCollection<Account>();
    var connectionString =
        string.Format("Data Source='{0}';Version=3;Default Command Timeout=10000;", UserPreferences.DatabasePath);
    AccountsGrid.CommitEdit();
    AccountsGrid.SelectedItem = null;

    MessageBox.Show(connectionString);
    try
    {
        using (var db = new MainDataContext(connectionString))
        {
            MessageBox.Show("step 4.5");
            var query = from a in db.Accounts
                where a.Inactive == 0 || a.Inactive == null || ShowInactiveCheckBox.IsChecked == true
                orderby a.AccountName, a.AccountNickname
                select a;

            try
            {
                MessageBox.Show("step 4.6");
                if (query.Any())
                {
                    MessageBox.Show("step 4.61");
                    foreach (var item in query)
                    {
                        MessageBox.Show("step 4.65");
                        accounts.Add(item);
                    }                            
                }

                MessageBox.Show("step 4.7");
                AccountsGrid.ItemsSource = accounts;
                MessageBox.Show("step 4.8");
            }
            catch (Exception e)
            {
                MessageBox.Show("accounts add " + e.Message);
                if (e.InnerException != null)
                {
                    MessageBox.Show(e.InnerException.Message);
                }
            }
        }
    }
    catch (Exception e)
    {
        MessageBox.Show("load accounts " + e.Message);
    }
}

我收到“步骤4.6”消息,然后是异常。我没有看到“步骤4.61”所以看起来错误在行if (query.Any())上,这是奇怪的,因为基础表是空的,所以没有结果。有没有人有任何想法在这里可能是什么问题?我确实使用exe和sqlite3.dll部署了LinqConnect DLL文件,所以这不应该是问题。

1 个答案:

答案 0 :(得分:0)

似乎我在部署机器上的正确输出文件夹中缺少sqlite3.dll。我本可以发誓它就在那里,但是当我将整个项目复制到另一台机器进行测试时,我仍然收到错误,当我查看bin目录时,该DLL丢失了。糟糕!