我创建了一个SqlLite 3 db文件并放在我项目的App_Data文件夹(ASP.Net Web API)中。我似乎无法连接到它。异常消息含糊不清,我无法确定是什么问题。权限?文件未找到?不知道。
我在web.config中创建了以下connectionString条目:
<connectionStrings>
<add name="LiteConnection" connectionString="Data Source=~\App_Data\repository.s3db;Version=3;" />
当我尝试打开()连接时抛出异常。我开始怀疑IISExpress(VS2012)可能无法写入此目录或其他内容吗?
private string _dbLitePath = ConfigurationManager.ConnectionStrings["LiteConnection"].ConnectionString;
...
public IDbConnection GetConnection()
{
try
{
if (_connection == null)
_connection = new SQLiteConnection(_dbLitePath);
if (_connection.State != ConnectionState.Open)
{
_connection.ConnectionString = _dbLitePath;
_connection.Open(); // kaaaaasplat!
}
}
catch (SQLiteException e)
{
}
return _connection;
}
答案 0 :(得分:3)
尝试将连接字符串更改为:
connectionString="Data Source=|DataDirectory|\repository.s3db
DataDirectory是一个替换字符串,用于指示路径 数据库。它消除了对完整路径进行硬编码的需要 因为数据库的完整路径可能导致几个问题 在不同的地方序列化。 DataDirectory也很容易 共享项目并部署应用程序。