原文:http://www.51aspx.com/CodeFile/WolfySQLiteDemo,22494/SQLiteHelper.cs.html
dll文件:http://pan.baidu.com/s/1dDEGgZR
public class SQLiteHelper
{
private static readonly string databaseName = AppDomain.CurrentDomain.BaseDirectory + ConfigurationManager.AppSettings["databaseName"];
/// <summary>
/// 创建数据库
/// </summary>
/// <param name="databaseName">数据库文件路径</param>
public static void CreateDataBase()
{
if (!File.Exists(databaseName))
{
SQLiteConnection.CreateFile(databaseName);
}
}
/// <summary>
/// 获得连接对象
/// </summary>
/// <returns></returns>
public static SQLiteConnection GetSQLiteConnection()
{
#region 方法一
SQLiteConnectionStringBuilder connStr = new SQLiteConnectionStringBuilder();
connStr.DataSource = databaseName;
connStr.Password = "123456";
connStr.Pooling = true;
return new SQLiteConnection(connStr.ToString());
#endregion
#region 方法二
//return new SQLiteConnection(string.Format("Data Source={0};password=123456", databaseName));
#endregion
}
/// <summary>
/// 匹配参数
/// </summary>
/// <param name="cmd"></param>
/// <param name="conn"></param>
/// <param name="cmdText"></param>
/// <param name="p"></param>
private static void PrepareCommand(SQLiteCommand cmd, SQLiteConnection conn, string cmdText, params object[] p)
{
if (conn.State == System.Data.ConnectionState.Closed)
{
conn.Open();
}
cmd.Parameters.Clear();
cmd.Connection = conn;
cmd.CommandText = cmdText;
cmd.CommandType = System.Data.CommandType.Text;
cmd.CommandTimeout = 30;
if (p != null)
{
foreach (object item in p)
{
cmd.Parameters.AddWithValue(string.Empty, item);
}
}
}
/// <summary>
/// 返回DataSet
/// </summary>
/// <param name="cmdText"></param>
/// <param name="p"></param>
/// <returns></returns>
public static DataSet ExecuteDataset(string cmdText, params object[] p)
{
DataSet ds = new DataSet();
SQLiteCommand cmd = new SQLiteCommand();
using (SQLiteConnection conn = GetSQLiteConnection())
{
PrepareCommand(cmd, conn, cmdText, p);
SQLiteDataAdapter sda = new SQLiteDataAdapter(cmd);
sda.Fill(ds);
}
return ds;
}
/// <summary>
/// 返回第一行
/// </summary>
/// <param name="cmdText"></param>
/// <param name="p"></param>
/// <returns></returns>
public static DataRow ExecuteDataRow(string cmdText, params object[] p)
{
DataSet ds = ExecuteDataset(cmdText, p);
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
{
return ds.Tables[0].Rows[0];
}
else
{
return null;
}
}
/// <summary>
/// 执行非查询操作 返回受影响的行数
/// </summary>
/// <param name="cmdText"></param>
/// <param name="p"></param>
/// <returns></returns>
public static int ExecuteNonQuery(string cmdText, params object[] p)
{
SQLiteCommand cmd = new SQLiteCommand();
using (SQLiteConnection conn = GetSQLiteConnection())
{
PrepareCommand(cmd, conn, cmdText, p);
return cmd.ExecuteNonQuery();
}
}
/// <summary>
/// 返回SQLiteDataReader
/// </summary>
/// <param name="cmdText"></param>
/// <param name="p"></param>
/// <returns></returns>
public static SQLiteDataReader ExecuteReader(string cmdText, params object[] p)
{
SQLiteConnection conn = GetSQLiteConnection();
SQLiteCommand cmd = new SQLiteCommand();
try
{
PrepareCommand(cmd, conn, cmdText, p);
SQLiteDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
return reader;
}
catch (Exception)
{
conn.Close();
throw;
}
}
/// <summary>
/// 返回结果集的首行首列
/// </summary>
/// <param name="cmdText"></param>
/// <param name="p"></param>
/// <returns></returns>
public static object ExecuteScalar(string cmdText, params object[] p)
{
SQLiteCommand cmd = new SQLiteCommand();
using (SQLiteConnection conn = GetSQLiteConnection())
{
PrepareCommand(cmd, conn, cmdText, p);
return cmd.ExecuteScalar();
}
}
/// <summary>
/// 分页获取DataSet
/// </summary>
/// <param name="recordCount"></param>
/// <param name="pageIndex"></param>
/// <param name="pageSize"></param>
/// <param name="cmdText"></param>
/// <param name="countText"></param>
/// <param name="p"></param>
/// <returns></returns>
public static DataSet ExecutePager(ref int recordCount, int pageIndex, int pageSize, string cmdText, string countText, params object[] p)
{
if (recordCount < 0)
recordCount = int.Parse(ExecuteScalar(countText, p).ToString());
DataSet ds = new DataSet();
SQLiteCommand command = new SQLiteCommand();
using (SQLiteConnection connection = GetSQLiteConnection())
{
PrepareCommand(command, connection, cmdText, p);
SQLiteDataAdapter da = new SQLiteDataAdapter(command);
da.Fill(ds, (pageIndex - 1) * pageSize, pageSize, "result");
}
return ds;
}
}