- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我找不到 Sqlite.Net data provider (System.Data.Sqlite.dll) 的问题(新开发已经 fork here),各种类及其方法抛出什么异常。我知道可以抛出 SqliteExceptions,但什么时候抛出?
我已确保我有随附的 System.Data.Sqlite.xml 文档文件,但它似乎没有列出每种方法抛出的异常。
我不想将不必要的代码包装到 try/catch block 中(或盲目地到处捕获通用异常)。
我知道 SqliteConnection 派生自 DbConnection , SqliteCommand 派生自 DbCommand ,所以如果有必要,我想我可以看看那里的文档。但是,没有一个基类会列出 SqliteException,那么什么时候会抛出这些类型的异常?
PS - 我使用的是 1.0.64 版(从 2009 年开始......目前无法升级)。
更新:
由于缺乏回应,是否有人使用 System.Data.Sqlite.dll?如果是这样,您采用什么方法来处理库中可用对象可能抛出的异常?是否有一些标准的方法来处理这些异常,因为似乎没有关于抛出的异常以及由哪些类引发的异常的文档?
更新 2:
我设法找到了位于 c:\program files\SQLite.NET\Doc\下的 SQLite.NET 文档(似乎很明显)。到目前为止的文档很棒,但是它没有告诉您抛出什么异常。到目前为止我能做的最好的事情就是查看继承的基类或实现的接口(interface)并查看抛出的异常。不过,这仍然无助于了解何时抛出 SqliteException 对象。
更新 3:
在获得源代码后,似乎没有一个类本身包含任何 /// <exception cref="ExceptionType">Something went wrong!</exception>
xml注释。这解释了为什么 SQLite.NET 帮助文件或 Visual Studio Intellisense 都没有列出任何可能抛出的异常。我创建了一个 ticket要求 xml 注释包含异常(exception)情况,如果在他们的优先级列表中太低,则提出自己添加它们。对于任何可能有兴趣的人,我会及时更新这个问题。
最佳答案
您可以使用“粗暴”的方式搜索代码或通过反射器查找异常。
是:反射器 --> 分析“System.Data.SQLite.SQLiteException” --> 实例化
System.Data.SQLite.SQLite3.Bind_Blob(SQLiteStatement, Int32, Byte[]) : Void
System.Data.SQLite.SQLite3.Bind_DateTime(SQLiteStatement, Int32, DateTime) : Void
System.Data.SQLite.SQLite3.Bind_Double(SQLiteStatement, Int32, Double) : Void
System.Data.SQLite.SQLite3.Bind_Int32(SQLiteStatement, Int32, Int32) : Void
System.Data.SQLite.SQLite3.Bind_Int64(SQLiteStatement, Int32, Int64) : Void
System.Data.SQLite.SQLite3.Bind_Null(SQLiteStatement, Int32) : Void
System.Data.SQLite.SQLite3.Bind_Text(SQLiteStatement, Int32, String) : Void
System.Data.SQLite.SQLite3.ChangePassword(Byte[]) : Void
System.Data.SQLite.SQLite3.ColumnMetaData(String, String, String, String&, String&, Boolean&, Boolean&, Boolean&) : Void
System.Data.SQLite.SQLite3.CreateCollation(String, SQLiteCollation, SQLiteCollation) : Void
System.Data.SQLite.SQLite3.CreateFunction(String, Int32, Boolean, SQLiteCallback, SQLiteCallback, SQLiteFinalCallback) : Void
System.Data.SQLite.SQLite3.GetIndexColumnExtendedInfo(String, String, String, Int32&, Int32&, String&) : Void
System.Data.SQLite.SQLite3.Open(String, SQLiteOpenFlagsEnum, Int32, Boolean) : Void
System.Data.SQLite.SQLite3.Prepare(SQLiteConnection, String, SQLiteStatement, UInt32, String&) : SQLiteStatement
System.Data.SQLite.SQLite3.Reset(SQLiteStatement) : Int32
System.Data.SQLite.SQLite3.SetPassword(Byte[]) : Void
System.Data.SQLite.SQLite3.SetTimeout(Int32) : Void
System.Data.SQLite.SQLite3.Step(SQLiteStatement) : Boolean
System.Data.SQLite.SQLite3_UTF16.Bind_Text(SQLiteStatement, Int32, String) : Void
System.Data.SQLite.SQLite3_UTF16.Open(String, SQLiteOpenFlagsEnum, Int32, Boolean) : Void
System.Data.SQLite.SQLiteBase.CloseConnection(SQLiteConnectionHandle) : Void
System.Data.SQLite.SQLiteBase.FinalizeStatement(SQLiteStatementHandle) : Void
System.Data.SQLite.SQLiteBase.ResetConnection(SQLiteConnectionHandle) : Void
System.Data.SQLite.SQLiteDataReader.CheckClosed() : Void
System.Data.SQLite.SQLiteStatement.BindParameter(Int32, SQLiteParameter) : Void
System.Data.SQLite.SQLiteTransaction.IsValid(Boolean) : Boolean
关于.net - 如何知道 System.Data.Sqlite 对象何时/什么异常被抛出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6444755/
我有一个带有帮助页面的 Web API 2 项目,该项目在本地运行良好,但当我将其推送到 Azure 时抛出此错误: Method not found: 'System.String System.S
我有两台服务器,但通常运行相同的设置 - IIS、SQL Server 等。一台给我这个错误,另一台没有。我从 Visual Studio 向两者发布相同的代码。 它们都在运行 .NET CLR Ve
System.out声明为 public static final PrintStream out。 但是你可以调用System.setOut()重新分配它。 嗯?如果它是 final,这怎么可能?
System.out被声明为 public static final PrintStream out。 但是您可以调用System.setOut()重新分配它。 嗯?如果是 final,这怎么可能?
我有这个 linq 查询: private void GetReceivedInvoiceTasks(User user, List tasks) { var areaIds = user.A
我有一个 MonoTouch 应用程序,当我为设备编译它时,出现以下错误: Error MT2002: Can not resolve reference: System.Boolean System
您好,我有一个名为 DailyVisitReport 的 View 。在该 View 中,我有两个名为 FromDate 和 toDate 的字段。如果我选择 FromDate 和 ToDate 取决
是否可以从 ObjectContext 对象中读取元组列表? 我在存储过程中有类似这样的数据库查询 SELECT T.Id as Item1, -- this is guid T.Wo
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我有一个方法可以从数据读取器的数据中生成类类型列表。 if (datareader != null && datareader .HasRows) { Dictionary pDict= GetP
我有一些旧的 C++ 代码,它们使用 stdio 进行输入和输出。该代码还通过 fork 生成新进程。它将 stdio 重新映射到每个新进程,以便每个 session 获取其各自的数据。 我正在考虑使
我的应用程序可以很好地构建/链接/部署到模拟器,但我只是第一次尝试将应用程序构建/部署到真实设备,并且链接器失败。 我不使用 System.Console或 ConsoleColor在我的应用程序的任
主要是我很好奇。 我们有一个名为 Unit 的对象在我们的代码库中 - 代表桥梁或道路的组件。在我们的例子中,看到带有 Unit 的 ReactiveUI 命令可能会模棱两可。作为声明中的泛型之一。
我试图将Object变量转换为StreamWriter。但是,它不起作用。有什么错? StreamWriter file = (StreamWriter) myObject; 最佳答案 myObjec
为什么以下不编译? using System; using System.Linq; using System.Linq.Expressions; public static class Extens
我正在使用 Visual Studio Community 2015 开发面向 .NET 4.5 的 Visual Basic 应用程序.我没有编写应用程序,所以我使用 NuGet 添加了所有缺失的依
我刚刚开始使用 powershell,我正在制作一个非常简单的加密功能。我想获取字符串中的每个字符,将其转换为 int 并添加一个选定的数字,然后将其转换回一个字符。 这工作正常: function
一些使用我的应用程序的人似乎变得越来越 System.MissingMethodException: Method not found: 'System.Object System.Windows.T
我是 C# 和实体的新手 我想知道是否有人在这里帮助我。我选择了哪个返回我的 customerid,所以我想将它作为参数传递给我的构造函数,我的构造函数参数类型是 guid 但我的选择类型不同,我不知
我是一名优秀的程序员,十分优秀!