Csv数据库CsvDb

在工控领域,经常遇到断电关机数据库文件损坏的情况,SQLite如此,LiteDb也是这样。ZTO有数万自动化扫描设备,每天都有数百台设备因断电数据库损坏等原因,而不得不重装软件。因此,设计了CsvDb,用于本地保存少量数据,一般只有几百几千行,极限不超过十万行。

Nuget包:NewLife.Core

源码地址:https://github.com/NewLifeX/X/blob/master/NewLife.Core/IO/CsvDb.cs

插入数据

Add插入一个对象(一行数据)到末尾。

var db = new CsvDb<GeoArea>((x, y) => x.Code == y.Code)
{FileName = "data/db.csv"
};
var model = new GeoArea
{Code = Rand.Next(),Name = Rand.NextString(14),
};
db.Add(model);// 把文件读出来
var lines = File.ReadAllLines(db.FileName.GetFullPath());
Assert.Equal(2, lines.Length);

实例化CsvDb时,需要指定模型类,它决定数据格式。构造函数中还可以指定比较器,可以理解为主键字段,用于查找目标数据行。

跑起来效果是这样:

查找数据

Find 用于查找一个对象,本质上引擎内部会遍历所有数据行,逐行对比主键。

var db = new CsvDb<GeoArea>((x, y) => x.Code == y.Code)
{FileName = "data/db.csv"
};
var model = db.Find(new GeoArea { Code = 1234 });

此外,还可以使用 FindAll 查找多行满足条件的数据,指定委托。

public IList<T> FindAll();
IList<T> FindAll(Func<T, Boolean> predicate, Int32 count = -1);
Int32 FindCount();

更新数据

Update 用于更新一个对象,本质上读取所有数据进入内存,修改对应数据后再写回去,成本较高,在数据量不大(小于1万)时问题不大。

var db = new CsvDb<GeoArea>((x, y) => x.Code == y.Code)
{FileName = "data/db.csv"
};
var model = new GeoArea
{Code = 1234,Name = "Stone",
};
db.Update(model);

删除数据

Remove 用于删除满足条件的对象,本质上读取所有数据进入内存,删除满足条件的对象后写回去,成本较高。如果删除后没有剩余数据行,则直接删除文件。

Int32 Remove(T model);
Int32 Remove(IEnumerable<T> models);
Int32 Remove(Func<T, Boolean> predicate);

总结

数万工控设备多年实践表明,Csv数据库很靠谱!

在断电关机的时候,csv文件同样也会损坏,只不过是CsvDb读取时跳过无法解析的错误行,避免了应用崩溃。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/304592.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Lucene的一些基本使用方法和概念 (JAVA)

Lucene是apache组织的一个用java实现全文搜索引擎的开源项目。其功能非常的强大&#xff0c;但api其实很简单的&#xff0c;它最主要就是做两件事:建立索引和进行搜索。1. 建立索引时最重要的几个术语* Document&#xff1a;一个要进行索引的单元&#xff0c;相当于数据库的一行…

java jdbc分页_使用JDBC进行分页查询

package day03;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;import java.sql.Statement;import day01.JdbcUtil;/** 演示&#xff1a;JDBC的批量处理*/public class Demo3 {public static void main(String[] args) {// testI…

python计算四舍五入_Python实现小数四舍五入的方法

对小数在Python中实现四舍五入的方法&#xff0c;不能使用round函数&#xff0c;round函数的执行的是HALF EVEN&#xff0c;不是四舍五入(HALF UP)。而使用decimal模块提供的接口&#xff0c;就可以精确实现十进制小数的四舍五入。本文对这个topic进行详细介绍。Python的浮点数…

一位像素艺术家用39张动图,将大自然的唯美尽收眼底…

Lioness 是一位像素艺术家&#xff0c;会制作 Gifs、icons、实体模型以及像素艺术教程等等。但其实&#xff0c;他的大部分精力集中在大自然灵感艺术&#xff0c;“Natural Palettes”便是其中一个项目。在这个项目里面&#xff0c;除了常见的配色图片以外&#xff0c;以 GIF 形…

一起学习设计模式--02.简单工厂模式

工厂模式是最常用的一类创建型设计模式。我们所说的工厂模式是指工厂方法模式&#xff0c;它也是使用频率最高的工厂模式。简单工厂模式是工厂方法模式的小弟&#xff0c;它不属于GoF 23种设计模式&#xff0c;但是在软件开发中应用也颇为频繁&#xff0c;通常将它作为学习其它…

python list remove 删除引用_Python——list列表操作一坑(remove)

问题发生背景&#xff1a;在一个对象被调用多次时候对象存入了列表暂时保存(主流程不能断开使用了while True)&#xff0c;然后实例化了大批对象&#xff0c;具体你可参考打飞机游戏或者坦克大战发射子弹&#xff0c;每个子弹一个实例&#xff0c;创建的多到一定时候肯定是要释…

雨后漫步长安街

雨后漫步长安街&#xff0c;四处是祖国60华诞的味道&#xff0c;和城楼合个影&#xff0c;待百年庆典的时候拿出来看一定别有一番滋味。那时我都是老婆婆了……转载于:https://blog.51cto.com/xurui/200059

hive 导入mysql数据库_求助 Hive 导入MYsql 数据库 报错啊

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼sqoop export \--connect "jdbc:mysql://localhost:3306/emp?characterEncodingUTF8" \--username root \--password 123456 \--input-fields-terminated-by , \--table t_dim_sqoop \--export-dir /user/hive/warehous…

聊一聊Load Average

背景 前段时间&#xff0c;由于有几个应用引入了 prometheus-net.DotNetRuntime 这个组件&#xff0c;导致系统 CPU 间歇性飙升。这是这个组件一个已知的雷。。同样也引发了系统的 Load Average (平均负载) 十分不正常。这是一台 4C8G 的服务器&#xff0c;Load Average 却是达…

我的邮局系统,欢迎大家注册!hotxf.com

我的邮局系统&#xff0c;欢迎大家注册&#xff01;hotxf.com mail.hotxf.com 可用于登陆MSN和邮件&#xff0c;25G网络硬盘我在使用 Windows Live 为 hotxf.com 托管电子邮件。我想邀请您在 hotxf.com 中创建电子邮件地址。您可以通过单击 https://domains.live.com/m…

优雅的读懂支持向量机 SVM 算法

转自&#xff1a;JerryLeadhttp://www.cnblogs.com/jerrylead/archive/2011/03/13/1982639.html简介支持向量机基本上是最好的有监督学习算法了。最开始接触SVM是去年暑假的时候&#xff0c;老师要求交《统计学习理论》的报告&#xff0c;那时去网上下了一份入门教程&#xff0…

python socket自动重连_详解python3中socket套接字的编码问题解决

一、TCP1、tcp服务器创建#创建服务器from socket import *from time import ctime #导入ctimeHOST #任意主机PORT 21567 #随机提供个端口号BUFSIZ 1024 # 缓冲区大小设置为1KB&#xff0c;可以根据网络性能和程序需要改变这个容量ADDR (HOST, PORT)tcpSerSock socket(AF_…

java压缩成.tar_java压缩tar.gz | 学步园

zlib、gzip、zip这三个概念的确比较容易混淆&#xff1a;zlib是一种数据压缩程序库&#xff0c;它的设计目标是处理单纯的数据(而不管数据的来源是什么)。gzip是一种文件压缩工具(或该压缩工具产生的压缩文件格式)&#xff0c;它的设计目标是处理单个的文件。gzip在压缩文件中的…

CentOS 介绍

CentOS是Community ENTerprise Operating System的简称&#xff0c;我们有很多人叫它社区企业操作系统&#xff0c;不管你怎么叫它&#xff0c;它都是linux的一个发行版本。CentOS并不是全新的linux发行版&#xff0c;倘若一说到RedHat这个大名&#xff0c;大家似乎都听过&…

Newbe.Claptrap 0.9.4 发布,全新构建

Newbe.Claptrap 0.9.4 发布&#xff0c;全新构建&#xff0c;全新内容&#xff0c;全新体验。简介 此次的版本更新虽然只是一个副版本更新。但实际上我们带来了非常多全新的内容。全方位将本框架带入到一个新的次代。我们希望我们的努力可以为在业务中需要 Actor 模式的开发者带…

【知识贴】战争中的数学应用

一、方程在海湾战争中的应用

Android Donut SDK 1.6r1 今日发布

Google今天公布了新版Android SDK,也就是Donut的最新1.6版,它可以帮助智能手机应用程序开发商迅速将自己的应用转换到Android系统上. SDK的发布有助于Google为自己寻找到更多的合作伙伴,为自己的Android Market添加人气,目前Donut已经可以下载. 下载:Android 1.6 SDK

java让对象分配在栈上_java – Hotspot何时可以在堆栈上分配对象?

我做了一些实验,以便了解Hotspot何时可以进行堆栈分配.事实证明,它的堆栈分配比基于available documentation的预期要有限得多.Choi“Escape Analysis for Java”引用的文章表明,只分配给局部变量的对象总是可以堆栈分配.但事实并非如此.所有这些都是当前Hotspot实现的实现细节…

开始CSRebot

写代码很久了了&#xff0c;时不时想把这些年学到的&#xff0c;用到的&#xff0c;或自己感悟到的&#xff0c;汇总一下&#xff0c;形成一个东西&#xff0c;或资料&#xff0c;或工具。但每当开始时就一片空白&#xff0c;总是觉得这些大家都会&#xff0c;这些只是自己片面…

toast弹窗_Android 开发(一):Toast弹窗与获取控件的值

前言&#xff1a;本人也是刚接触Android开发&#xff0c;自己也在摸索中&#xff0c;在实现功能的过程中走了不少弯路&#xff0c;其中很重要的原因之一就是查询不到想要的内容&#xff0c;所以想把自己的经验分享出来。首先是Toast的应用&#xff0c;直接上关键代码。Toast to…