说明:开始几个是基本的方法,后面稍微封装了下

 public class SqliteHelper
{
//连接字符串
private static readonly string str = ConfigurationManager.ConnectionStrings["conStr"].ConnectionString; /// <summary>
/// 增删改
/// 20180723
/// </summary>
/// <param name="sql">sql语句</param>
/// <param name="param">sql参数</param>
/// <returns>受影响的行数</returns>
public static int ExecuteNonQuery(string sql, params SQLiteParameter[] param)
{
//try
//{
using (SQLiteConnection con = new SQLiteConnection(str))
{
using (SQLiteCommand cmd = new SQLiteCommand(sql, con))
{
con.Open();
if (param != null)
{
cmd.Parameters.AddRange(param);
} string sql2 = cmd.CommandText;
//con.Close();
return cmd.ExecuteNonQuery();
}
}
//}
//catch (SQLiteException se)
//{
// return 0;
//}
} /// <summary>
/// 查询
/// 20180723
/// </summary>
/// <param name="sql">sql语句</param>
/// <param name="param">sql参数</param>
/// <returns>首行首列</returns>
public static object ExecuteScalar(string sql, params SQLiteParameter[] param)
{
using(SQLiteConnection con = new SQLiteConnection(str))
{
using(SQLiteCommand cmd = new SQLiteCommand(sql, con))
{
con.Open();
if (param != null)
{
cmd.Parameters.AddRange(param);
} return cmd.ExecuteScalar();
}
}
} /// <summary>
/// 多行查询
/// 20180723
/// </summary>
/// <param name="sql">sql语句</param>
/// <param name="param">sql参数</param>
/// <returns>SQLiteDateReader</returns>
public static SQLiteDataReader ExecuteReader(string sql, params SQLiteParameter[] param)
{
using (SQLiteConnection con = new SQLiteConnection(str))
{
using (SQLiteCommand cmd = new SQLiteCommand(sql, con))
{
if (param != null)
{
cmd.Parameters.AddRange(param);
}
try
{
con.Open();
return cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
}
catch (Exception ex)
{
con.Close();
con.Dispose();
throw ex;
}
}
} } /// <summary>
/// 查询多行数据
/// 20180723
/// </summary>
/// <param name="sql">sql语句</param>
/// <param name="param">sql参数</param>
/// <returns>一个表</returns>
public static DataTable ExecuteTable(string sql, params SQLiteParameter[] param)
{
DataTable dt = new DataTable();
using (SQLiteDataAdapter sda = new SQLiteDataAdapter(sql, str))
{
if (param != null)
{
sda.SelectCommand.Parameters.AddRange(param);
}
sda.Fill(dt);
}
return dt;
} /// <summary>
/// 查询封装
/// 20180725
/// </summary>
/// <param name="tbName">表名</param>
/// <param name="fields">查询需要的字段名:"id, name, age"</param>
/// <param name="where">查询条件:"id = 1"</param>
/// <param name="orderBy">排序:"id desc"</param>
/// <param name="limit">分页:"0,10"</param>
/// <param name="param">sql参数</param>
/// <returns>受影响行数</returns>
public static DataTable QueryTable(string tbName, string fields = "*", string where = "", string orderBy = "", string limit = "", params SQLiteParameter[] param)
{
//排序
if (orderBy != "")
{
orderBy = "ORDER BY " + orderBy;//Deom: ORDER BY id desc
} //分页
if (limit != "")
{
limit = "LIMIT " + limit;//Deom: LIMIT 0,10
} string sql = string.Format("SELECT {0} FROM `{1}` WHERE {2} {3} {4}", fields, tbName, where, orderBy, limit); //return sql;
return SqliteHelper.ExecuteTable(sql, param); } /// <summary>
/// 数据插入
/// 20180725
/// </summary>
/// <param name="tbName">表名</param>
/// <param name="insertData">需要插入的数据字典</param>
/// <returns>受影响行数</returns>
public static int ExecuteInsert(string tbName, Dictionary<String , String> insertData)
{
string point = "";//分隔符号(,)
string keyStr = "";//字段名拼接字符串
string valueStr = "";//值的拼接字符串 List<SQLiteParameter> param = new List<SQLiteParameter>();
foreach (string key in insertData.Keys)
{
keyStr += string.Format("{0} `{1}`", point, key);
valueStr += string.Format("{0} @{1}", point, key);
param.Add(new SQLiteParameter("@"+key, insertData[key]));
point = ",";
}
string sql = string.Format("INSERT INTO `{0}`({1}) VALUES({2})", tbName, keyStr, valueStr); //return sql;
return ExecuteNonQuery(sql, param.ToArray()); } /// <summary>
/// 执行Update语句
/// 20180725
/// </summary>
/// <param name="tbName">表名</param>
/// <param name="where">更新条件:id=1</param>
/// <param name="insertData">需要更新的数据</param>
/// <returns>受影响行数</returns>
public static int ExecuteUpdate(string tbName, string where, Dictionary<String, String> insertData)
{
string point = "";//分隔符号(,)
string kvStr = "";//键值对拼接字符串(Id=@Id) List<SQLiteParameter> param = new List<SQLiteParameter>();
foreach (string key in insertData.Keys)
{
kvStr += string.Format("{0} {1}=@{2}",point, key, key);
param.Add(new SQLiteParameter("@" + key, insertData[key]));
point = ",";
}
string sql = string.Format("UPDATE `{0}` SET {1} WHERE {2}", tbName, kvStr, where); return ExecuteNonQuery(sql, param.ToArray()); } }

最新文章

  1. 关于RESTFul初步理解
  2. Netty实现高性能RPC服务器
  3. 快速设置IP的脚本
  4. Android 使用HorizontalScrollView 实现Gallery效果
  5. JenKins 环境搭建 for Centos6.5
  6. JSpider是一个用Java实现的WebSpider
  7. 流式计算-Jstorm提交Topology过程(上)
  8. Java 类的加载过程(阿里面试题)
  9. Python基础-week03
  10. 一入OI深似海 3 —— 纪念我最后一次PJ(上)
  11. 3. Linux系统磁盘分区介绍
  12. 【BZOJ5194】Snow Boots
  13. Hadoop-HDFS
  14. 十分钟了结MySQL information_schema
  15. easyUI中numberbox的校验
  16. php计算程序运行时间
  17. 初识DOM
  18. 关于 java,nio,bufferedreader,bytebuffer
  19. CSS 中的字体兼容写法:用CSS为英文和中文字体分别设置不同的字体
  20. tomcat manager

热门文章

  1. luogu题解 P5020 【货币系统 】
  2. Oracle JDK与OpenJDK到底有什么不同?
  3. 基于Spark Grahpx+Neo4j 实现用户社群发现
  4. python利用select实现的Socket Server
  5. Java8中的流操作-基本使用&amp;性能测试
  6. Kubernetes容器集群管理环境 - Prometheus监控篇
  7. .net持续集成测试篇之Nunit that断言
  8. 设计模式:与SpringMVC底层息息相关的适配器模式
  9. Go中的文件读写
  10. Vue系列:滚动页面到指定位置实现