我找不到 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/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚