java实现的非关系型数据库:nosqldb
创始人
2024-05-07 14:29:05
0

nosqldb

  • 一、nosqldb介绍
  • 二、nosqldb功能介绍
  • 三、数据存储结构介绍
    • 1. 数据文件存储结构(data.nosqldb)
    • 2.索引文件存储结构(index.mbdb)
  • 三、优化点
    • 1. 不支持连表查询
    • 2. 不支持分片存储
    • 3. 碎片整理


一、nosqldb介绍

github地址 https://github.com/MaBo2420935619/nosqldb

nosqldb是一个用Java实现的基于文件存储的 非关系型数据库管理系统,由个人开发者mabo独立开发

nosqldb 将不同表的数据保存在不同的目录下,而不是将所有数据放在一个大仓库内,这样就增加了查询速度并提高了灵活性

image

每个表的目录下有2个文件:

  • data.nosqldb存储数据
  • index.nosqldb存储索引
    如下图所示
    image

二、nosqldb功能介绍

nosqldb无需对表结构进行定义,即无需创建表就可以进行数据库操作。
对表数据进行操作支持两种方式,一种是基于对象进行操作,一种是基于json格式的数据进行操作。
如下图所示对person表进行插入操作

  • 对象操作
 public static void insert() {Person zhangsan = new Person().setId("1").setName("zhangsan");NoSqlObjTemplate noSqlObjTemplate = new NoSqlObjTemplate();noSqlObjTemplate.insert(zhangsan);}
  • json操作
 		JSONArray array = new JSONArray();JSONObject jsonObject = new JSONObject();jsonObject.put("id","2");jsonObject.put("msgid","6");array.add(jsonObject);TableService.insert("person",array,"id");

nosqldb支持增删改查操作,具体使用样例参考github中example

三、数据存储结构介绍

1. 数据文件存储结构(data.nosqldb)

如图所示,数据在文件中以json字符串进行存储,读取的时候在转化为对象或者json进行使用
并且该数据库支持批量存储
在这里插入图片描述

2.索引文件存储结构(index.mbdb)

索引文件一条数据存储了三条数据用符号 | 进行分割,key存储数据的唯一id,position存储数据的指针,方便查询数据,表头的999008用于表示数据的数据量大小,因为查询数据采用二分法查询,所以需要记录数据的数据量。

在这里插入图片描述

三、优化点

1. 不支持连表查询

2. 不支持分片存储

目前数据库的的一张表数据都存储在同一张表中。
可以进行优化,当数据库文件大小超过一定大小时,将文件存储到不同文件中。当使用分片存储时,需要修改索引结构,增加分片编号,查询时根据索引中的分片编号选择文件进行查询。

3. 碎片整理

由于删除操作的存在,删除时为了保证其他数据的位置不发生变化,只是对当前行的数据进行空字符串替代,并没有进行行数据的移动操作。所以当大量数据被删除时,会导致数据库的文件中存在大量的空行。所以删除操作并不会使数据文件变小。所以最好时能进行数据库文件的定时碎片整理。重新整理后,重新生成数据库的索引。

目前该数据库还在使用测试阶段,并且github中提供了该数据库的所有源代码。
欢迎各位大佬提出意见和建议进行数据库优化升级!

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...