-
Notifications
You must be signed in to change notification settings - Fork 36
/
DBConnection.vb
92 lines (73 loc) · 2.79 KB
/
DBConnection.vb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
Imports System.Data.SQLite
Imports System.IO
Public Class DBConnection
Private DB As SQLiteConnection
Private Lock As New Object
Public Sub New(ByVal DBFilePath As String, ByVal DBName As String)
Dim DBFileName As String = Path.Combine(DBFilePath, DBName)
DB = New SQLiteConnection
DB.ConnectionString = "Data Source=" & DBFileName & ";Version=3;"
If DB.State = ConnectionState.Open Then
DB.Close() ' Check if the DB is open and will lock on re-connection
DB.Dispose()
GC.Collect()
Threading.Thread.Sleep(5000)
DB.ConnectionString = "Data Source=" & DBFileName & ";Version=3;"
End If
Try
Call OpenDB()
Catch ex As Exception
Call DisplayDBException(ex)
End ' Close program
End Try
End Sub
Private Sub OpenDB()
' Before opening, delete any shm and wal files that might be in the folder
On Error Resume Next
File.Delete("EVEIPH DB.sqlite-shm")
File.Delete("EVEIPH DB.sqlite-wal")
DB.Open()
Call ExecuteNonQuerySQL("PRAGMA auto_vacuum = FULL; PRAGMA synchronous = NORMAL; PRAGMA locking_mode = NORMAL; PRAGMA cache_size = 10000; PRAGMA page_size = 4096; PRAGMA temp_store = DEFAULT; PRAGMA journal_mode = WAL; PRAGMA count_changes = OFF")
On Error GoTo 0
End Sub
Private Sub DisplayDBException(ThrownException As Exception)
MsgBox("IPH was unable to open the primary database and will now close." & vbCrLf & vbCrLf & "Error message: " & ThrownException.Message, vbCritical)
Call WriteMsgToLog(ThrownException.ToString)
End Sub
Public Sub CloseDB()
DB.Close()
DB.Dispose()
GC.Collect()
End Sub
Public Function DBREf() As SQLiteConnection
Return DB
End Function
Public Sub ExecuteNonQuerySQL(ByVal SQL As String)
Dim DBExecuteCmd As SQLiteCommand
ErrorTracker = SQL
SyncLock Lock
DBExecuteCmd = DB.CreateCommand
DBExecuteCmd.CommandText = SQL
DBExecuteCmd.ExecuteNonQuery()
DBExecuteCmd.Dispose()
DBExecuteCmd = Nothing
End SyncLock
ErrorTracker = ""
End Sub
Public Sub BeginSQLiteTransaction()
Call ExecuteNonQuerySQL("BEGIN;")
End Sub
Public Sub CommitSQLiteTransaction()
Call ExecuteNonQuerySQL("END;")
End Sub
Public Sub RollbackSQLiteTransaction()
Call ExecuteNonQuerySQL("ROLLBACK;")
End Sub
Public Function TransactionActive() As Boolean
If DB.AutoCommit Then
Return False
Else
Return True
End If
End Function
End Class