CS3223 Database Systems Implementation Project
AY2018/2019 Semester 2
School of Computing
National University of Singapore
This project focuses on the implementation of a simple SPJ (Select-Project-Join) query engine to illustrate how query processing works in modern database management systems (DBMS), specifically relational databases (RDBMS). More information about the project requirements can be found at here.
This repository presents our approach to this project. We are a team consisting of undergraduate students from the National University of Singapore, comprising of
- Niu Yunpeng
- Sun Shengran
- Jia Zhixin
Implementation Outline
Based on the given template, we have implemented the following operators in this SPJ query engine:
- Block Nested Loops Join (see BlockNestedJoin.java)
- Sort Merge join (see SortMergeJoin.java)
- External sort (using k-way merge algorithm) (see Sort.java)
DISTINCT
operator (see Distinct.java)GROUP BY
operator (see Groupby.java)
We have tried to follow the Volcano iterator model to implement the various operators. However, there does exist some operators (such as Sort
) which are blocking and cannot use the iterator model.
In addition, we have implemented a new hybrid randomized operator (see here), which consists of both the iterative improvement (II) algorithm (see RandomII.java) and the simulated annealing (SA) algorithm (see RandomSA.java).
Setup Instructions
- Make sure you have installed Java not lower than JDK1.8.
- Looks like the project works fine in a newer version of Java (like JDK 11) as well.
- Make sure you have installed the latest version of IntelliJ IDEA.
- Clone the repository into your local repository by
git clone git@github.com:yunpengn/CS3223.git
. - Make sure you have configured the import order in IDE correctly:
- Go to
File
>Settings...
(Windows/Linux), orIntelliJ IDEA
>Preferences...
(macOS); - Select
Editor
>Code Style
>Java
and choose theImports
tab; - Set both
Class count to use import with '*'
andNames count to use static import with '*'
to 999; - For
Import Layout
: follow the order ofimport static all other imports
,<blank line>
,import java.*
,<blank line>
,import javax.*
,<blank line>
,import org.*
,<blank line>
,import com.*
,<blank line>
,import all other imports
.
- Go to
- Select
Import Project
from theCS3223
folder you have just cloned to create the project:- Use
Create project from existing sources
option; - Go to
Project Structure
>Libraries
, addJava
withlib/CUP
,lib/JLEX
,lib/hamcrest-core-1.3.jar
andlib/junit-4.13-beta-2.jar
. - Go to
Project Structure
>Modules
:- Mark
src
andtestcases
folder asSources
; - Mark
test
folder asTests
; - Mark
classes
folder andout
folder (if exists) asExcluded
.
- Mark
- Use
- Run
build.bat
(Windows) orbuild.sh
(macOS or Linux) to build the project.
Development Workflow
- We follow the feature branch workflow
- That means, you should NOT fork this repository. Instead, create a new branch and work on it.
- Every single line of code must be reviewed by someone else.
- Whenever you create a PR, assign it to yourself and request review from someone else.
- After a PR is merged, delete the branch immediately (using the button on the page of that PR so that it is possible to revert later, do NOT delete it manually).
- Follow the normal coding styles. You should especially pay attention to the following aspects:
- Never use wildcard import. Only import the classes you need;
- Every class & method should have a header comment using valid syntax of JavaDoc;
- Each indentation level should 4 spaces (rather than tab);
- Use logging if necessary (for this project, we would use
System.out.println
&System.err.println
for simplicity).
- To generate the scanner class with JLex library, follow the steps below:
- Go to the
lib
folder bycd lib/
; - Run
java JLex.Main ../src/qp/parser/scanner.lex
; - The command in last step will generate a new file named
scanner.lex.java
, use this file to replace the originalScanner.java
file. Make sure you remember to change the class name inside the file as well (as the original generated file name is not desirable).
- Go to the
- To generate the parser class with the JavaCup library, follow the steps below:
- Go to the
lib/CUP
folder bycd lib/CUP/
; - Run
java java_cup.Main ../../src/qp/parser/parser.cup
; - Replace the original
parser.java
andsym.java
with the generated files.
- Go to the
References
- CS3223 Module Website
- JLex: A Lexical Analyzer Generator for Java
- CUP: Parser Generator for Java