我正在学习 VB.Net,需要使用开源 System.Data.SQLite ADO.Net 解决方案来处理 SQLite 数据库
我在 HOWTO 部分找到的示例仅是 C# 语言的。有人可以在 VB.Net 中提供一个简单的示例吗?我可以研究它来了解如何在插入多个参数时使用事务?
FWIW,这是我正在处理的代码:
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Dim SQLconnect As New SQLite.SQLiteConnection()
Dim SQLcommand As SQLite.SQLiteCommand
Dim SQLtransaction As SQLite.SQLiteTransaction
SQLconnect.ConnectionString = "Data Source=test.sqlite;"
SQLconnect.Open()
SQLcommand = SQLconnect.CreateCommand
SQLcommand.CommandText = "CREATE TABLE IF NOT EXISTS files (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, hash TEXT);"
SQLcommand.ExecuteNonQuery()
'================ INSERT starts here
SQLtransaction = SQLconnect.BeginTransaction()
Dim myparam As New SQLite.SQLiteParameter()
SQLcommand.CommandText = "INSERT INTO [files] ([name],[hash]) VALUES(?,?)"
SQLcommand.Parameters.Add(myparam)
'How to set all parameters? myparam.Value
SQLcommand.ExecuteNonQuery()
SQLtransaction.Commit()
'================ INSERT ends here
SQLcommand.CommandText = "SELECT id,name,hash FROM files"
'How to tell if at least one row?
Dim SQLreader As SQLite.SQLiteDataReader = SQLcommand.ExecuteReader()
While SQLreader.Read()
ListBox1.Items.Add(SQLreader(1))
End While
SQLcommand.Dispose()
SQLconnect.Close()
End Sub
谢谢。
编辑:对于那些感兴趣的人,这里有一些工作代码:
SQLtransaction = SQLconnect.BeginTransaction()
SQLcommand.CommandText = "INSERT INTO files (name,hash) VALUES(@name,@hash)"
SQLcommand.Parameters.AddWithValue("@name", "myfile")
SQLcommand.Parameters.AddWithValue("@hash", "123456789")
SQLcommand.ExecuteNonQuery()
SQLtransaction.Commit()
事务方法应该是相同的(前提是 SQLite API 支持事务)。对于多个参数,您需要为每个参数声明一个 SqlParameter 类实例,然后将每个参数添加到查询中。
Dim myparam As New SQLite.SQLiteParameter()
myparam.Value = "Parameter 1's value"
Dim myparam2 As New SQLite.SQLiteParameter()
myparam2.Value = "Parameter 2's value"
SQLcommand.Parameters.Add(myparam)
SQLcommand.Parameters.Add(myparam2)
至于你的问题“如何判断是否至少一行”,标准 .NET SQLReader 有一个“HasRows”属性。 IE。
If SQLreader.HasRows Then
While SQLreader.Read()
ListBox1.Items.Add(SQLreader(1))
End While
End If
我认为 SQLite 驱动程序也应该如此。
抱歉,如果这段代码不是干净的 VB,我已经大约 5 年没有碰过它了!
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)