Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bursasha/postgresql-ifix-database
PostgreSQL database with create script, insert script, queries, and description 📑
https://github.com/bursasha/postgresql-ifix-database
cross-join database group-by left-join natural-joins postgresql query relational-algebra relational-database right-join sql
Last synced: 20 days ago
JSON representation
PostgreSQL database with create script, insert script, queries, and description 📑
- Host: GitHub
- URL: https://github.com/bursasha/postgresql-ifix-database
- Owner: bursasha
- Created: 2022-07-13T20:20:49.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2024-06-13T15:26:37.000Z (7 months ago)
- Last Synced: 2024-06-13T17:47:25.585Z (7 months ago)
- Topics: cross-join, database, group-by, left-join, natural-joins, postgresql, query, relational-algebra, relational-database, right-join, sql
- Language: PLpgSQL
- Homepage:
- Size: 521 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Database Project for iFix Service Center Chain 📊
## Project Structure: 📁
- `assets/`: Contains images and documentation files.
- `CreateScript.sql`: SQL script for creating the database schema.
- `InsertScript.sql`: SQL script for inserting initial data into the database.
- `Queries.sql`: SQL script containing various queries to interact with the database.
- `README.md`: The main README file for the project.## Technology Stack: 🔍
- **Database**: PostgreSQL
- **Languages**: SQL, PLpgSQL
- **Tools**: DBeaver, pgAdmin
- **Concepts**: Relational Database Management, Data Integrity, Entity-Relationship Modeling## iFix Service Center Chain Database Description: 🛠️
A year ago, on January 1, 2021, a chain of iFix service centers opened in England, focusing primarily on repairing devices from different manufacturers and selling various accessories for gadgets.All branches of the service centers maintain personal databases. All customers and employees receive their own identification number upon registration, where they indicate their first name, last name, phone number, and can leave their email as an additional way of communicating with the service center. Employees are recorded with their working position, salary, and date of employment in the database. Each branch has several technicians (from 2 to 5), managed by one manager.
All customers of the service center bring their gadgets for repair (at least 1) and can buy accessories for their devices (as many as they want). Visitors' gadgets are registered using their IMEI numbers (6-9 digits), which are unique for all devices worldwide, along with the manufacturer, model of the device, and year of production (if necessary). The types of breakdowns of the brought devices and the payment method of each client are entered into the database. You can pay by card, with bank transfer, or cash. Each visitor can be served by several employees of the branch.
In addition to people and branches, their addresses are stored in the database. Each address has its own unique code, building number, street, district, and postal code. Since a considerable number of branches have opened in the country, the address is also associated with the city where the person lives or where the branch is located.
## Loops Discussion: 🔄
1. **Employee – Person – Address – Branch:**
* It is more convenient and rational to store the addresses of customers and branches in one table in the database, as it is necessary for the service center's operations. The result of this loop is that customers can live at the same address where a branch of the service center is located. More than one person can live at the same address, but the addresses of customers and branches do not overlap, which is described in the integrity constraint.2. **Employee – Employee:**
* Only 1 manager or from 2 to 5 technicians can be employed in a branch. The technicians are led by a manager who is the main individual in each branch. Based on this loop, the manager can subordinate/lead himself, and this case is constrained by the integrity restriction.3. **Person – Service – Employee:**
* As mentioned in the first loop, it is more rational to store data about all people (both customers and employees) in one database table. The result of this loop is that the branch employees can serve themselves, but it is not a problem since none of the employees stop working simultaneously, and the employee pays for the service like all customers.## Conceptual Scheme: 💡
![Conceptual scheme](/assets/conceptual_scheme.png)## Relational Scheme: 🗂️
![Relational scheme](/assets/relational_scheme.png)## Sources: 📚
- [ČVUT FIT Documentation](https://users.fit.cvut.cz/~hunkajir/dbs2/main.xml#D17)
- [ČVUT FIT Main XML](https://users.fit.cvut.cz/~hunkajir/dbs/main.xml)
- [PostgreSQL Documentation](https://www.postgresql.org/files/documentation/pdf/12/postgresql-12-A4.pdf)
- [Stack Overflow](https://stackoverflow.com/)
- [Mockaroo Data Generation](https://www.mockaroo.com/)
- [ČVUT FIT Courses](https://courses.fit.cvut.cz/BI-DBS/)