[原创]基于文件系统的轻量级单机数据库引擎
作者:V君 发布于:2013-11-27 15:16 Wednesday 分类:折腾手记
前言
(觉得啰嗦就直接跳下去看正文吧-_-||)
V君一直在对单机桌面小程序数据存储纠结, 你说.net自带的序列化吧, 由于封装过度不灵活, 实体结构改变的话不晓得会发生什么问题...
你说SqlCe吧, 这货支持Linq2sql确实不错, 但... 这货在建表之后不能改字段名称(至少设计器不行...) 最要命的是平台依赖, 不能跨平台到mono...
再说SQLite吧, 这货足够“适用”了吧? 我的答案是 -- 还不行! 对于V君这个用贯了Linq查询的无脑码农来说, 手写SQL什么的早就不想玩啦... 试过套上 DbLinq 来操作, 结果发现 DbLinq 还有很多不完善的地方, 像子查询什么的直接爆出“未实现” (什么? 你说上SqlServer? 拜托! 一个小程序你扯这么重量级的玩意...)
够了! 自己写一个吧!! 能用Linq的跨平台的单机数据库!!!
正文
这货的名称: FsDb (Rev2)
名称含义: File (Flat) System (Simple) Database
目前实现程度的特点
- 数据直接JSON化保存到文件系统 (Newtonsoft.Json)
- 即时增量写入, 程序崩溃不怕数据丢失
- 提供数据压缩来减小体积和提升加载速度 (自定义归档+SharpZipLib::Gz)
- 完全基于.Net托管代码实现, 随便跨平台
- 支持使用Linq做查询
- 支持实体之间的弱关系(无约束)维护(EntitySet/EntityRef)
整个引擎类库结构大概如下
FsDb (命名空间)
|-FsDbEngine (数据库引擎, 实现文件读写/压缩解压)
|-FsDbCollection<T> where T : FsDbEntityBase
(实体集合, 当做表就对了. 这是仿照芒果的叫法)
|-FsDbEntityBase (实体基类, 要求继承的侵入式设计, 懒了(>д<) )
|-FsDbEntitySet (实体子关联, 从DataContext抄来的命名 )
|-FsDbEntityRef (实体父关联, 从DataContext抄来的命名 )
使用流程:
- 定义实体类, 设计关联(详见实例)
- 指定存放数据的路径初始化引擎实例, 通常是exe旁边的data文件夹
- 传入实体类泛型参数, 从引擎取得集合
- 对集合进行CURD操作
- 对集合调用压缩功能(非必须)
结语
目前还没有太多想说的话 (Pia---
V君已把这项目发布到自己搭建的SVN Git上了~
(想必进来看的人最关心的就是找到取得的途径吧wwwwwwwwwwwwwwwww)
蛤蛤又把这个月的0篇文章消灭喇~~
评论:
blogger
Google Web Translator
热门日志
随机日志
最新日志
最新评论
- V君
@Quartz:(出现)... - Quartz
怎么不见人了呢... - V君
@Soar:DHCP 协议相... - V君
@Soar:当然是非... - Soar
@V君:谢谢 有空... - Soar
搞一个 1230v3+B85... - V君
@Soar:另外,也可... - V君
@Soar:iscsi服务端... - Soar
难怪这么卡,尤其... - Soar
clone了源码,提示...
分类
存档
- 2024年5月(1)
- 2023年7月(1)
- 2023年5月(1)
- 2022年11月(1)
- 2022年10月(1)
- 2022年9月(1)
- 2022年8月(1)
- 2022年7月(1)
- 2022年6月(1)
- 2022年5月(2)
- 2022年4月(1)
- 2022年3月(1)
- 2022年2月(1)
- 2022年1月(1)
- 2021年12月(1)
- 2021年11月(1)
- 2021年10月(1)
- 2021年9月(1)
- 2021年8月(1)
- 2021年7月(1)
- 2021年6月(1)
- 2021年5月(1)
- 2021年4月(1)
- 2021年3月(1)
- 2021年2月(1)
- 2021年1月(1)
- 2020年12月(1)
- 2020年11月(1)
- 2020年10月(2)
- 2020年9月(1)
- 2020年8月(1)
- 2020年7月(1)
- 2020年6月(1)
- 2020年5月(1)
- 2020年4月(2)
- 2020年3月(3)
- 2020年2月(1)
- 2020年1月(1)
- 2019年12月(1)
- 2019年11月(1)
- 2019年10月(1)
- 2019年9月(1)
- 2019年8月(2)
- 2019年7月(1)
- 2019年6月(1)
- 2019年5月(1)
- 2019年4月(1)
- 2019年3月(1)
- 2019年2月(1)
- 2019年1月(2)
- 2018年12月(2)
- 2018年11月(1)
- 2018年10月(3)
- 2018年9月(4)
- 2018年8月(6)
- 2018年7月(4)
- 2018年6月(1)
- 2018年5月(2)
- 2018年4月(2)
- 2018年3月(3)
- 2018年2月(1)
- 2018年1月(1)
- 2017年12月(1)
- 2017年10月(2)
- 2017年9月(1)
- 2017年8月(2)
- 2017年7月(1)
- 2017年6月(5)
- 2017年5月(2)
- 2017年4月(2)
- 2017年3月(3)
- 2017年2月(2)
- 2017年1月(2)
- 2016年12月(3)
- 2016年11月(2)
- 2016年10月(3)
- 2016年9月(4)
- 2016年8月(2)
- 2016年7月(4)
- 2016年6月(3)
- 2016年5月(1)
- 2016年4月(4)
- 2016年3月(3)
- 2016年2月(1)
- 2016年1月(5)
- 2015年12月(4)
- 2015年11月(5)
- 2015年10月(1)
- 2015年9月(6)
- 2015年8月(4)
- 2015年7月(1)
- 2015年6月(6)
- 2015年5月(3)
- 2015年4月(3)
- 2015年3月(2)
- 2015年2月(1)
- 2015年1月(3)
- 2014年12月(1)
- 2014年11月(1)
- 2014年10月(1)
- 2014年9月(3)
- 2014年8月(1)
- 2014年7月(1)
- 2014年6月(1)
- 2014年5月(3)
- 2014年4月(1)
- 2014年3月(1)
- 2014年2月(2)
- 2014年1月(1)
- 2013年12月(2)
- 2013年11月(2)
- 2013年10月(1)
- 2013年9月(3)
- 2013年8月(14)
- 2013年7月(7)
- 2013年4月(1)
- 2013年3月(4)
- 2013年2月(6)
- 2013年1月(6)
- 2012年12月(8)
- 2012年11月(6)
2014-01-17 01:55