This repository was archived by the owner on Mar 2, 2021. It is now read-only.
forked from Peteys93/MCForge-MCLawl
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSQLite.cs
90 lines (83 loc) · 3.84 KB
/
SQLite.cs
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
/*
Copyright 2011 MCForge (modified by Sinjai for use with SinCraft)
Dual-licensed under the Educational Community License, Version 2.0 and
the GNU General Public License, Version 3 (the "Licenses"); you may
not use this file except in compliance with the Licenses. You may
obtain a copy of the Licenses at
http://www.opensource.org/licenses/ecl2.php
http://www.gnu.org/licenses/gpl-3.0.html
Unless required by applicable law or agreed to in writing,
software distributed under the Licenses are distributed on an "AS IS"
BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
or implied. See the Licenses for the specific language governing
permissions and limitations under the Licenses.
*/
using System;
using System.Data;
using System.Data.SQLite;
namespace SinCraft
{
namespace SQL
{
public static class SQLite //: Database //Extending for future improvement (Making it object oriented later).
{
private static string connStringFormat = "Data Source =" + Server.apppath + "/SinCraft.db; Version =3; Pooling ={0}; Max Pool Size =1000;";
private static SQLiteParameterCollection parameters = new SQLiteCommand().Parameters;
public static string connString { get { return String.Format(connStringFormat, Server.DatabasePooling); } }
[Obsolete("Preferably use Database.executeQuery instead")]
public static void executeQuery(string queryString)
{
Database.executeQuery(queryString);
}
[Obsolete("Preferably use Database.executeQuery instead")]
public static DataTable fillData(string queryString, bool skipError = false)
{
return Database.fillData(queryString, skipError);
}
/// <summary>
/// Adds a parameter to the parameterized SQLite query.
/// Use this before executing the query.
/// </summary>
/// <param name="name">The name of the parameter</param>
/// <param name="param">The value of the parameter</param>
public static void AddParams(string name, object param) {
parameters.AddWithValue(name, param);
}
/// <summary>
/// Clears the parameters added with <see cref="SinCraft.SQL.MySQL.AddParams(System.string, System.string)"/>
/// <seealso cref="SinCraft.SQL.MySQL"/>
/// </summary>
public static void ClearParams() {
parameters.Clear();
}
private static void AddSQLiteParameters(SQLiteCommand command) {
foreach (SQLiteParameter param in parameters)
command.Parameters.Add(param);
}
private static void AddSQLiteParameters(SQLiteDataAdapter dAdapter) {
foreach (SQLiteParameter param in parameters)
dAdapter.SelectCommand.Parameters.Add(param);
}
internal static void execute(string queryString) {
using (var conn = new SQLiteConnection(SQLite.connString)) {
conn.Open();
using (SQLiteCommand cmd = new SQLiteCommand(queryString, conn)) {
AddSQLiteParameters(cmd);
cmd.ExecuteNonQuery();
conn.Close();
}
}
}
internal static void fill(string queryString, DataTable toReturn) {
using (var conn = new SQLiteConnection(SQLite.connString)) {
conn.Open();
using (SQLiteDataAdapter da = new SQLiteDataAdapter(queryString, conn)) {
AddSQLiteParameters(da);
da.Fill(toReturn);
}
conn.Close();
}
}
}
}
}