Skip to content

Latest commit

 

History

History
110 lines (59 loc) · 4.02 KB

README.md

File metadata and controls

110 lines (59 loc) · 4.02 KB

Employee-Project

Created: Oct 20, 2020 8:40 PM

Updated: Oct 25, 2020 00:39 AM

Table of contents

Requirements

Perform data migration from a CSV file to a MySQL database.

The files provided contain details about Employees. (EmployeeRecords.csv / EmployeeRecordsLarge.csv)

Your program will need to read the data from the CSV file and then import the data into the database. Please note that there may be errors in the CSV file that you need to check for. It is recommend to create some kind of collection to store the invalid employee records, so they can be checked later.

The program needs thorough testing at all points to ensure the data migration has taken place correctly. It should also report on the time takes to read the CSV, populate the database and the overall time for the migration.

Be sure to consider the use of design patterns to follow good clean code standards (DTO, DAO).

Introduction

Employee Project is a product that allow for the import of CSV files to a MySQL database. Through the use of threading and batch execution, it is capable of quick imports. It encompasses concepts such as: database link, threading, reading/writing to a file, logging, DTO, DAO, functional programming.

  • Database

    MySQL database.

  • Threading

    Allowed for the persistence of data to occur in ~4.5 seconds from ~370 seconds. The number of threads can be adjusted in the setup screen.

  • Reading/Writing

    Making use of the BufferedReader in combination with FileReader.

  • Logging

    Duplicate records are stored into an external file to be manually reviewed.

  • Data transfer object (DTO)

    Used to reduce the number of calls to the database. It is present as the Employee class.

  • Data access object (DAO)

    Provides CRUD operations without exposing details about the database.

The project makes use of Maven as the dependency management and build tool, JUnit-Jupiter for unit testing, log4j2 for logging throughout the program, mysql-connector to establish a database link.

Built with

The project was built with IntelliJ.

The database designed to work with the product is MySQL.

Getting started

You need to have downloaded and installed:

  1. IntelliJ, either the community version or the ultimate one.

  2. MySQL Workbench

  3. MySQL Server

Then you need to clone the repo. For windows users, run the following command in Git:

git clone https://github.com/waLLxAck/Sparta-Global-SortManager/tree/master

Note: You can use IntelliJ for cloning, too.

Once you've done that, you have to open up the project in the IntelliJ and create a database.properties file inside the resources folder with the following information:

Please change database settings accordingly.

url = jdbc:mysql://localhost:3306/dbEmployees?serverTimezone=GMT

username = *ENTER USERNAME*

password = *ENTER PASSWORD*

dbEmployees - this is the name of the database

GMT - this is your time zone

root - default username

password - provide the password you used in the MySQL server installation

Usage

This project can be used to efficiently persist CSV files to a database.

Warning: For any alterations of the provided Employee format, DTO must be changed.

Future work

Add dynamic CSV compatibility

  • When a new CSV file is placed in the file directory read its header
  • Adjust the SQL statements to match the data from the headers
  • Be able to perform data persistance of a non-employee object