ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

C#的sqlite orm - praeclarum/sqlite-net笔记

2022-01-18 15:03:54  阅读:234  来源: 互联网

标签:praeclarum sqlite return t96List C# uploadTime DBConfig public conn


此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;
        }

标签:praeclarum,sqlite,return,t96List,C#,uploadTime,DBConfig,public,conn
来源: https://blog.csdn.net/rocklee/article/details/122560091

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有