Enter the following commands in MySQL shell
- Create a database 'AdAgency'
DROP DATABASE IF EXISTS AdAgency;
CREATE DATABASE AdAgency;
- Change current database
USE AdAgency;
- source the dump
SOURCE AdAgency.sql
- Create a venv in python
python3 -m venv DnA
- Switch to the virtual environment created
source DnA/bin/activate
- Install dependencies
pip install -r requirements.txt # or pip-sync requirements.txt
- Run script
./main.py
ls
: View optionscd [arg]
: Navigate to arg (option name or option number or..
)[num]
: Navigate to num option numberclear
: Clear the outputexit
: Close apphelp
: View these commands anytime!
Suggestions for new commands are always welcome 😝
Main
│
└───Add
│ │ Actor
│ │ Director
│ │ Brand
│ │ Channel
│ │ Show
│ │ Product
│ │ Ad
│ │ Guardian
│
└───Update
│ │
│ └───Actor
│ │ │ Account Number
│ │ │ Name
│ │ │ Height & Weight
│ │ │ Add Preferred Brand
│ │ │ Remove Preferred Brand
│ │
│ └───Director
│ │ │ Account Number
│ │ │ Name
│ │ │ Salary
│ │ │ Supervisor
│ │
│ └───Brand
│ │ │ POC Email
│ │ │ POC Phone
│ │
│ └───Product
│ │ │ Price
│ │ │ Description
│ │
│ └───Channel
│ │ │ Base Price
│ │
│ └───Show
│ │ │ Surcharge
│ │ │ Air an Ad
│ │ │ Remove an Ad
│ │
│ └───Ad
│ │ Air in a show
│ │ Remove from a show
│
└───Delete
│ │ Actor
│ │ Director
│ │ Brand
│ │ Channel
│ │ Show
│ │ Product
│ │ Ad
│ │ Guardian
│
└───Read
│ Actors
│ Directors
│ Brands
│ Channels
│ Shows
│ Products
│ Ads
│ Guardians
│ Ad-Show Relations
│ Actor's preffered brands
│ Actors with Physical features
│ Average Ad Production cost
│ Maximum preferred brand
│ Partial text search for shows
│ Partial text search for actor
│ Best shows for an ad
│ Shows with surcharge less than a value
│ Maximum of sum of contract money of brand
│ Bill for an Ad
│ Shows list by amount
This file contains the main function which asks the username and password from the user and connects to the database by calling the function connect_to_database which is defined in the app/utils/connect.py
file.
This is the dump file for our AdAgency Database. It contains the queries needed to create all the tables and load them with relevant data with basic checks.
This file constains the implementation of the menu interface through which the user can choose the operation which he/she wishes to perform on the database using the command line interface. Depending on user input it calls the corresponding the functions.
This file contains the implementation of the create queries. The user can add new records of Actor, Director, Brands, Products, Ads, Shows, Channels, Preferred Brands of the Actors and Ads displayed in the shows. If the entered data is invalid (by checking in python and in MySQL) we return and ask the user to enter the data again. Also, please add the guardians before adding a junior actor and provide aadhar card of guardians of the actor.
This file contains the implementation of the read queries and our functional requirements. The user can request all the records of Actor, Director, Brands, Products, Ads, Shows, Channels, Preferred Brands of the Actors and Ads displayed in the shows along with other user specific functional requirements which can be used for analysis.
This file contains the implementation of the update queries. We allow the user to update product description and price, channel baseprice, show surcharge, account number and name of the person, height and weight of the actor, director salary and supervisor.
This file constains the implementation of the delete queries. Deletion of Actor, Director, Brand, Channel, Product, Ad, Show, Guardian are allowed along with deletion of relationship instances in prefers and displayedBetween table.
- Gurkirat Singh (2019101069)
- Shrey Gupta (2019101058)
- Sanchit Arora (2019101047)