C#的sqlite orm - praeclarum/sqlite-net笔记
2022/1/19 2:10:53
本文主要是介绍C#的sqlite orm - praeclarum/sqlite-net笔记,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
此orm需要用到sqlite3的运行库,从这里下载:https://www.sqlite.org/download.html
安装source: https://github.com/praeclarum/sqlite-net/blob/master/src/SQLite.cs
应用:
1、建立基础类
class DBConfig { public SQLiteConnection connection { get; set; } public DBConfig() { var databasePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "lpm.db"); connection = new SQLiteConnection(databasePath); } ~DBConfig() { connection.Close(); } } ## 1、建立/连接s
2、应用
建立数据库、表
private DBConfig dBConfig; private SQLiteConnection conn; public PLMDB() { this.dBConfig = new DBConfig(); conn = dBConfig.connection; conn.CreateTable<T96PDLogTable>(); conn.CreateTable<Keyvalue>(); }
统计查询
public long UnSubmitCount() { return conn.ExecuteScalar<long>("select count(*) from T96PDLogTable where uploadTime is null"); }
查询记录
public List<T96PDLogTable> getUnunLoad(int limitNum) { IEnumerable <T96PDLogTable> r = conn.Query<T96PDLogTable>("select * from T96PDLogTable where uploadTime is null order by RecSEQ limit " + limitNum); return r.ToList(); }
参数化
public int removeOldData(int keepDays) { DateTime utc = Utils.toUTC(DateTime.Now.AddDays(-keepDays)); long tm = Utils.CurrentMillis(utc); return conn.Execute("delete from T96PDLogTable where uploadTime is not null and f96_create_dt<?", tm); }
条件查询Where
public bool markToUploaded(String recseq)
{
var query = conn.Table().Where(v => v.RecSEQ.Equals(recseq));
…
}
批量增加
public bool addT96(List<T96PDLogTable> t96List) { try { return conn.InsertAll(t96List, true) == t96List.Count; } catch (Exception e) { if (!e.Message.Contains("UNIQUE constraint")) { throw e; } return true; } }
批量修改
public bool markToUploaded(List<T96PDLogTable> t96List) { t96List.ForEach(c => c.uploadTime = DateTime.Now.ToString()); return conn.UpdateAll(t96List, true) == t96List.Count; }
这篇关于C#的sqlite orm - praeclarum/sqlite-net笔记的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2022-03-01沐雪多租宝商城源码从.NetCore3.1升级到.Net6的步骤
- 2024-12-06使用Microsoft.Extensions.AI在.NET中生成嵌入向量
- 2024-11-18微软研究:RAG系统的四个层次提升理解与回答能力
- 2024-11-15C#中怎么从PEM格式的证书中提取公钥?-icode9专业技术文章分享
- 2024-11-14云架构设计——如何用diagrams.net绘制专业的AWS架构图?
- 2024-05-08首个适配Visual Studio平台的国产智能编程助手CodeGeeX正式上线!C#程序员必备效率神器!
- 2024-03-30C#设计模式之十六迭代器模式(Iterator Pattern)【行为型】
- 2024-03-29c# datetime tryparse
- 2024-02-21list find index c#
- 2024-01-24convert toint32 c#