# hivedb **Repository Path**: Hugu1e/hivedb ## Basic Information - **Project Name**: hivedb - **Description**: HiveDB是一个采用java编写的轻量关系型数据库 - **Primary Language**: Unknown - **License**: GPL-3.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2025-04-24 - **Last Updated**: 2025-05-05 ## Categories & Tags **Categories**: Uncategorized **Tags**: Java ## README # MYDB MYDB 是一个 Java 实现的简单的数据库,部分原理参照自 MySQL、PostgreSQL 和 SQLite。实现了以下功能: - 数据的可靠性和数据恢复 - 两段锁协议(2PL)实现可串行化调度 - MVCC - 两种事务隔离级别(读提交和可重复读) - 死锁处理 - 简单的表和字段管理 - 简陋的 SQL 解析(因为懒得写词法分析和自动机,就弄得比较简陋) - 基于 socket 的 server 和 client ## 运行方式 注意首先需要在 pom.xml 中调整编译版本,如果导入 IDE,请更改项目的编译版本以适应你的 JDK 首先执行以下命令编译源码: ```shell mvn compile ``` 接着执行以下命令以 /tmp/mydb 作为路径创建数据库: ```shell mvn exec:java -Dexec.mainClass="top.guoziyang.mydb.backend.Launcher" -Dexec.args="-create /tmp/mydb" ``` 随后通过以下命令以默认参数启动数据库服务: ```shell mvn exec:java -Dexec.mainClass="top.guoziyang.mydb.backend.Launcher" -Dexec.args="-open /tmp/mydb" ``` 这时数据库服务就已经启动在本机的 9999 端口。重新启动一个终端,执行以下命令启动客户端连接数据库: ```shell mvn exec:java -Dexec.mainClass="top.guoziyang.mydb.client.Launcher" ``` 会启动一个交互式命令行,就可以在这里输入类 SQL 语法,回车会发送语句到服务,并输出执行的结果。 windows: ```shell mvn exec:java "-Dexec.mainClass=top.guoziyang.mydb.backend.Launcher" "-Dexec.args=-create ./tmp/mydb" ```