基于Java语言实现的一个轻量级关系型数据库系统-支持数据持久化存储与恢复-两段锁协议实现可串行化调度-MVCC多版本并发控制-...

基于Java语言实现的一个轻量级关系型数据库系统-支持数据持久化存储与恢复-两段锁协议实现可串行化调度-MVCC多版本并发控制-...MYDB MYDB 是一个 Java 实现的简单的数据库 部分原理参照自 MySQL PostgreSQL 和 SQLite 实现了以下功能 数据的可靠性和数据恢复 两段锁协议 2PL 实现可串行化调度 MVCC 两种事务隔离级别 读提交和可重复读 死锁处理 简单的表和字段管理 简陋的 SQL 解析 因为懒得写词法分析和自动机 就弄得比较简陋 基于 socket 的 server 和

大家好,我是讯享网,很高兴认识大家。这里提供最前沿的Ai技术和互联网信息。

# MYDB

MYDB 是一个 Java 实现的简单的数据库,部分原理参照自 MySQL、PostgreSQL 和 SQLite。实现了以下功能:

  • 数据的可靠性和数据恢复
  • 两段锁协议(2PL)实现可串行化调度
  • MVCC
  • 两种事务隔离级别(读提交和可重复读)
  • 死锁处理
  • 简单的表和字段管理
  • 简陋的 SQL 解析(因为懒得写词法分析和自动机,就弄得比较简陋)
  • 基于 socket 的 server 和 client

运行方式

注意首先需要在 pom.xml 中调整编译版本,如果导入 IDE,请更改项目的编译版本以适应你的 JDK

首先执行以下命令编译源码:

mvn compile 

接着执行以下命令以 /tmp/mydb 作为路径创建数据库:

GPT plus 代充 只需 145mvn exec:java -Dexec.mainClass="top.guoziyang.mydb.backend.Launcher" -Dexec.args="-create /tmp/mydb" 

随后通过以下命令以默认参数启动数据库服务:

mvn exec:java -Dexec.mainClass="top.guoziyang.mydb.backend.Launcher" -Dexec.args="-open /tmp/mydb" 

这时数据库服务就已经启动在本机的 9999 端口。重新启动一个终端,执行以下命令启动客户端连接数据库:

GPT plus 代充 只需 145mvn exec:java -Dexec.mainClass="top.guoziyang.mydb.client.Launcher" 

会启动一个交互式命令行,就可以在这里输入类 SQL 语法,回车会发送语句到服务,并输出执行的结果。

一个执行示例:

小讯
上一篇 2026-03-26 20:05
下一篇 2026-03-26 20:03

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/246432.html