Java手写数据库(第一章)

第一章 准备知识

(一) 实现的步骤

  1. 定义语法文件,我们使用JavaCC定义语法文件(sql.jj)描述Sql语句的词法和语法规则。
  2. 构建词法分析器与语法分析器,使用JavaCC的命令行工具javacc将Sql.jj文件编译为Java代码。
  3. 编写Sql执行引擎,实现对不同Sql语句的解析和执行逻辑,例如执行SELECT、UPDATE、DELETE等操作。
  4. 实现数据库模型,建立数据库的数据模型,包括表、列、行等内容。在模型中可以定义表的属性、索引、限制、触发器等内容,以支持更加复杂的查询和更新操作。
  5. 实现与数据库相关的操作,例如增加、删除、修改、查询、排序、聚集等操作。这些操作需要与数据库模型进行交互,并将操作结果返回给客户端

(二) JavaCC简介

JavaCC是一个用于生成Java语言解析器的工具,全称为Java Compiler Compiler。它将基于语法规则的文本描述(称为语法文件)转换为Java语言解析器,可以用于解析复杂的文本格式,如编程语言、网页标记语言等。JavaCC使用Java语言编写,具有可移植性和灵活性。
要在Maven项目中引入Javacc,您需要做以下几步:

  1. 在Maven项目的pom.xml文件中添加以下依赖:
<dependency>
    <groupId>org.javacc</groupId>
    <artifactId>javacc</artifactId>
    <version>6.1.2</version>
</dependency>
  1. 在项目源代码的目录下创建一个.jj文件,该文件是使用Javacc定义语法和词法规则的文件。
  2. 在pom.xml的构建配置中添加以下代码来为Javacc插件指定.jj文件所在的目录和生成代码所在的目录:
<build>
  <plugins>
    <plugin>
      <groupId>org.javacc</groupId>
      <artifactId>javacc-maven-plugin</artifactId>
      <version>2.7</version>
      <executions>
        <execution>
          <goals>
            <goal>javacc</goal>
          </goals>
        </execution>
      </executions>
      <configuration>
        <outputDirectory>src/main/java</outputDirectory>
        <grammar>your_folder/sql.jj</grammar>
      </configuration>
    </plugin>
  </plugins>
</build>

其中,your_folder是存放.jj文件的文件夹,sql.jj是您创建的.jj文件的名称。

  1. 运行Maven插件进行编译。在终端中输入以下命令:

Copy

mvn exec:java

此时,Maven将会编译.jjt文件并生成Java源代码。通过以上步骤,就可以在Maven项目中使用Javacc进行语法规则的定义和编译了。

(三) Javacc NBP简介

Javacc NBP(Naming Bounded Parser)是基于Javacc开发的一种语法分析器,它支持在定义语法规则时为非终结符号指定名字(Name),并对它们进行监控(Bound),以确保它们的使用符合规范和约束。如果有任何不符合要求的错误,Javacc NBp会抛出异常并中止程序。以下是Javacc NBp的使用方法:

一、安装Javacc

首先,您需要在计算机上安装Javacc。可以从官网(https://javacc.github.io/javacc/)下载最新版本的Javacc,并按照说明进行安装。安装后,您可以通过在命令行或终端窗口中运行javacc命令来使用它。

二、编写Javacc NBP文件

在安装完Javacc后,您可以使用文本编辑器编写Javacc NBp文件(通常以.jj扩展名结尾)。这个文件包含语法规则、词法规则和其他配置信息,用来定义您想要分析的编程语言。

以下是一个简单的Javacc NBP文件示例,用于解析一个加法表达式:

PARSER_BEGIN(Calculator)
 
public class Calculator {
    public static void main(String[] args) throws ParseException {
        Calculator parser = new Calculator(System.in);
        System.out.println(parser.calculate());
    }
 
    public int calculate() throws ParseException {
        return expression();
    }
}

PARSER_END(Calculator)

SKIP: {
    " " | "\t" | "\n" | "\r"
}

TOKEN: {
    <ADD: "+">
    | <INT: (["0"-"9"])+ >
}

int expression():
{
    int left, right;
}
{
    left = term() ( <ADD> right = term() { left += right; } )*
    {
        return left;
    }
}

int term():
{
    Token t;
    int i;
}
{
    i = <INT>
    {
        return i.intValue();
    }
}

三、生成解析器代码

使用Javacc命令行工具,将Javacc NBp文件转换为Java代码。您可以在命令行中输入以下命令:

javacc Calculator.jj

该命令会生成Calculator.java和TokenMgrError.java两个文件。其中Calculator.java文件包含解析器的代码。

四、使用解析器进行语法分析

编译并运行生成的Calculator.java文件。这将启动一个计算器程序,并对输入的表达式进行分析和计算(例如,2+3)。

相关文章

Java运行环境配置

若要在计算机上运行Java程序,需要配置Java运行环境(JRE)或Java开发工具包(JDK)。以下是在Windows操作系统上配置Java运行环境的步骤:下载Java安装程序:前往Oracle官方...

「Java后端」开发环境搭建指南

1. Java1.1 Java安装及配置统一使用Oracle Java,版本为1.8,安装完成后配置环境变量JAVA_HOME及PATH。在命令行执行java -version应显示正确版本号。2....

JVM内存溢出常用排查命令

最近,有一个项目在不超过的12小时内,一定会内存溢出(java.lang.OutOfMemoryError:Java heap space)。由于当时比较忙,没有时间去具体分析,所以暂时只是加大了JV...

JVM常用指令

目录:一.引言二.基础故障处理工具2.1 概述2.2. jps:虚拟机进程状况工具2.3. jstat:虚拟机统计信息监视工具2.3. jinfo:java配置信息工具2.5. jmap:Java...

探秘Clojure:编程世界的“隐藏高手”

为什么你该认识 Clojure在编程语言的浩瀚星空中,Clojure 宛如一颗遗世独立的小众星辰,散发着独特而迷人的光芒。尽管它的知名度远不及 Java、Python 等主流语言,但在专业开发者的圈子...