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中提供了该数据库的所有源代码。
欢迎各位大佬提出意见和建议进行数据库优化升级!

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...