/// <summary>
/// 操作Sqlite
/// </summary>
public class OperSqlite
{
/// <summary>
/// 修改密码
/// </summary>
/// <param name="DataSource"></param>
/// <param name="OldPassword"></param>
/// <param name="NewPassword"></param>
/// <returns></returns>
public static bool PasswordChange(string DataSource, string OldPassword, string NewPassword)
{
try
{
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = OldPassword;
conn.ConnectionString = SCS.ToString();
conn.Open();
//Change Password
conn.ChangePassword(NewPassword);
}
return true;
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
return false;
}
}
/// <summary>
/// 创建数据库
/// </summary>
/// <param name="NewTable">New Table Name</param>
/// <param name="NewWords">Words list of the New Table</param>
/// <param name="CreatNew">Creat or Add to the Database(Using to make Multi Tables)</param>
/// <returns></returns>
public static bool Creat(string DataSource, string NewTable, List<string> NewWords, bool CreatNew = false, string PassWord = null)
{
try
{
if (CreatNew)
{
//Creat Data File
SQLiteConnection.CreateFile(DataSource);
}
//Creat Table
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = PassWord;
conn.ConnectionString = SCS.ToString();
conn.Open();
//Creat
string Bazinga = "create table [" + NewTable + "] (";
foreach (string Words in NewWords)
{
Bazinga += "[" + Words + "] TEXT COLLATE NOCASE,";
}
//Set Primary Key
//The Top item from the "NewWords"
Bazinga += @"PRIMARY KEY ([" + NewWords[0] + "]))";
DbCommand cmd = conn.CreateCommand();
cmd.Connection = conn;
cmd.CommandText = Bazinga;
cmd.ExecuteNonQuery();
}
return true;
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
return false;
}
}
/// <summary>
/// 获取表段
/// </summary>
/// <returns>list of Tables</returns>
public static List<string> GetTables(string DataSource, string PassWord = null)
{
List<string> ResultLst = new List<string>();
try
{
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = PassWord;
conn.ConnectionString = SCS.ToString();
conn.Open();
using (SQLiteCommand tablesGet = new SQLiteCommand("SELECT name from sqlite_master where type='table'", conn))
{
using (SQLiteDataReader tables = tablesGet.ExecuteReader())
{
while (tables.Read())
{
try
{
ResultLst.Add(tables[0].ToString());
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
}
}
}
}
}
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
}
return ResultLst;
}
/// <summary>
/// 获取字段
/// </summary>
/// <param name="TargetTable">Target Table</param>
/// <returns>list of Words</returns>
public static List<string> GetWords(string DataSource, string TargetTable, string PassWord = null)
{
List<string> WordsLst = new List<string>();
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = PassWord;
conn.ConnectionString = SCS.ToString();
conn.Open();
using (SQLiteCommand tablesGet = new SQLiteCommand(@"SELECT * FROM " + TargetTable, conn))
{
using (SQLiteDataReader Words = tablesGet.ExecuteReader())
{
try
{
for (int i = 0; i < Words.FieldCount; i++)
{
WordsLst.Add(Words.GetName(i));
}
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
}
}
}
}
return WordsLst;
}
/// <summary>
/// 取值
/// </summary>
/// <returns>list of Values</returns>
public static List<string> GetValues(string DataSource, string Sql, string GetColumu, string PassWord = null)
{
List<string> ResultLst = new List<string>();
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = PassWord;
conn.ConnectionString = SCS.ToString();
conn.Open();
using (SQLiteCommand cmd = new SQLiteCommand(Sql, conn))
{
using (SQLiteDataReader dr = cmd.ExecuteReader())
{
while (dr.Read())
{
try
{
ResultLst.Add(dr[GetColumu].ToString());
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
}
}
}
}
}
return ResultLst;
}
/// <summary>
/// 插入数据
/// </summary>
/// <param name="DataSource"></param>
/// <param name="TargetTable"></param>
/// <returns></returns>
public static bool Insert(string DataSource, string TargetTable, string ColumnS, string ValueS, string PassWord = null)
{
try
{
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = PassWord;
conn.ConnectionString = SCS.ToString();
conn.Open();
//Insert
DbCommand cmd = conn.CreateCommand();
cmd.CommandText = "insert into [" + TargetTable + "] (" + ColumnS + ") values (" + ValueS + ")";
cmd.ExecuteNonQuery();
return true;
}
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
return false;
}
}
/// <summary>
/// 删除数据
/// </summary>
/// <param name="DataSource"></param>
/// <param name="TargetTable"></param>
/// <param name="Word"></param>
/// <param name="Value"></param>
/// <returns></returns>
public static bool Delete(string DataSource, string TargetTable, string Word, string Value, string PassWord = null)
{
try
{
//Connect
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = PassWord;
conn.ConnectionString = SCS.ToString();
conn.Open();
DbCommand cmd = conn.CreateCommand();
cmd.Connection = conn;
//Delete
cmd.CommandText = "Delete From " + TargetTable + " where [" + Word + "] = '" + Value + "'";
cmd.ExecuteNonQuery();
}
return true;
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
return false;
}
}
/// <summary>
/// 执行Sqlite指令
/// </summary>
/// <param name="DataSource"></param>
/// <param name="Sql"></param>
/// <returns></returns>
public static bool SqlCommand(string DataSource, string Sql, string PassWord = null)
{
try
{
using (SQLiteConnection conn = new SQLiteConnection())
{
SQLiteConnectionStringBuilder SCS = new SQLiteConnectionStringBuilder();
SCS.DataSource = DataSource;
SCS.Password = PassWord;
conn.ConnectionString = SCS.ToString();
conn.Open();
using (SQLiteCommand cmd_Re = new SQLiteCommand(Sql, conn))
{
cmd_Re.ExecuteNonQuery();
}
}
return true;
}
catch (Exception E)
{
MessageBox.Show(E.Message, "提示");
return false;
}
}
}
操作Sqlite
最新推荐文章于 2022-08-09 14:28:31 发布