IMDB Movie Database (in C#, Java, JS and PHP) - Exam Preparation for the Tech Module @ SoftUni (December 2017)
You are assigned to create a Simple Movie Database App. The application should hold movies, which are the main app entities. The functionality of the app should support creating, listing, editing and deleting movies. The application should persist the data into a database. Data validation and error handling is a plus but is not mandatory.
Your application should be built on each one of the following technologies:
- Symfony framework
- Twig view engine
- Doctrine ORM framework
- MySQL database
- NodeJS + ExpressJS frameworks
- Handlebars.js view engine
- Mongoose data access framework
- MongoDB database
- Spring framework (Spring MVC + Spring Boot + Spring Data)
- Thymeleaf view engine
- JPA / Hibernate ORM + Spring Data data access frameworks
- MySQL database
- ASP.NET framework (ASP.NET MVC + Entity Framework)
- Razor view engine
- Entity Framework ORM framework
- MSSQL Server database
The Film entity holds 3 properties:
id- technology-dependent identifier (ObjectIDfor JavaScript,intfor all other technologies)name- nonempty textgenre- nonempty textdirector- nonempty textyear- integer (1900-2100)
This is the user interface should consists of the following pages (under the designated routes):
Route: / (GET)
List all movies.
Route: /create (GET and POST)
GET shows a form to create a film. POST saves the form data into the database as new film.
Route: /delete/{id} (GET and POST)
GET shows a form to delete a certain film. POST confirms deleting a film and removes the film from the database.
Route: /edit/{id} (GET and POST)
GET shows a form to edit a certain film. POST confirms editing a film and modifies the film in the database.
Implement the IMDB App on all mentioned 4 technology stacks.
Before you start working, make sure you download all the dependencies (packages) required for each technology and set up the databases! Below are instructions on how to do this:
- Go into the root directory of the project (where the bin folder resides)
- Make sure you’ve started your MySQL server (either from XAMPP or standalone)
- Open a shell / command prompt / PowerShell window in that directory (shift + right click --> open command window here)
- Enter the
php composer.phar installcommand to restore its Composer dependencies (described incomposer.json) - Enter the
php bin/console doctrine:database:createcommand - Enter the
php bin/console doctrine:schema:update ---forcecommand - Done!
- Go into the root directory of the project (where the bin folder resides)
- Make sure you’ve started your MongoDB server:
mongod.exe --dbpath path/to/db/directory - Open a shell / command prompt / PowerShell window in the root directory (shift + right click --> open command window here)
- Enter the
npm installcommand to restore its Node.js dependencies (described inpackage.json) - Done!
The C# project will automatically resolve its NuGet dependencies (described in packages.config) using the NuGet package restore when the project is built.
The Java project will automatically resolve its Maven dependencies (described in pom.xml) when the project is built.