Skip to content

Latest commit

 

History

History
253 lines (174 loc) · 13.3 KB

README.md

File metadata and controls

253 lines (174 loc) · 13.3 KB

Data-Base-Management-Systems

Projects I made in DBMS. I use Microsoft sql server, Azure Data Studio, Visual paradigm for my projects.

Table of Contents

DBMS

A database management system (DBMS) is system software for creating and managing databases. A DBMS makes it possible for end users to create, protect, read, update and delete data in a database. The most prevalent type of data management platform, the DBMS essentially serves as an interface between databases and users or application programs, ensuring that data is consistently organized and remains easily accessible.

SQL

Structured Query Language (SQL) let access and manage database.

  • execute queries against a database
  • retrieve data from a database
  • insert records in a database
  • update records in a database
  • delete records from a database
  • create new databases
  • create new tables in a database
  • create stored procedures in a database
  • create views in a database
  • set permissions on tables, procedures, and views

Relationships

  • One to one ->
  • One to many ->
  • Many to one ->
  • Many to many ->

Project Description

Production Tracking Management System; It has a database showing the relationships between assets such as Product, Firm and Raw Material. The Entity-Relationship Diagram of this system is demonstrated with the Visual Paradigm.

  1. Product Asset: Contains Code, Name and Total Cost information.
  2. Firm Presence: Contains Name and Country information.
  3. Raw Material Asset: Contains Code, Name, Quantity and Unit Cost information.
  4. Each company can produce more than one product.
  5. Each Raw Material can be used in the production of more than one product. Each Product can be created by more than one raw material. The production date of the product created using raw materials and the warranty date of the product should be recorded.

Create, Alter, Keys

  • CREATE ->

The CREATE DATABASE statement is used to create a new SQL database. The CREATE TABLE statement is used to create a new table in a database.

  • ALTER ->

The ALTER TABLE statement is used to add, delete, or modify columns in an existing table and is also used to add and drop various constraints on an existing table.

  • KEYS ->

The PRIMARY KEY constraint uniquely identifies each record in a table. Primary keys must contain UNIQUE values, and cannot contain NULL values. A table can have only ONE primary key; and in the table, this primary key can consist of single or multiple columns (fields).

The FOREIGN KEY constraint is used to prevent actions that would destroy links between tables. A FOREIGN KEY is a field (or collection of fields) in one table, that refers to the PRIMARY KEY in another table. The table with the foreign key is called the child table, and the table with the primary key is called the referenced or parent table.

Project Description

  1. Database name must be VTYSLab2.
  2. CustomerID, OrderID and ProductID must not be NULL when creating the table. All other information must be NULL.

Select From Where

  • SELECT ->

The SELECT statement is used to select data from a database. The data returned is stored in a result table, called the result-set.

  • FROM ->

The FROM statement is used to specify which table to deal with.

  • WHERE ->

The WHERE clause is used to filter records. It is used to extract only those records that fulfill a specified condition.

Project Description

  1. Retrieve the data from the Departments table.
  2. Bring the job_id data in the jobs table using DISTINCT.
  3. Bring the data of employees and jobs working in the Executive Assistant position.
  4. Bring the data of employees working in Department B as first_name, last_name and salary.
  5. Bring the employees working in Department_B and Executive Assistant position as first_name, last_name and salary.
  6. Bring the data of employees working in Department B with salary information as first_name, last_name and salary in descending order.

Order by, Like, Null, Count, Distinct

  • Order by ->

The ORDER BY keyword sorts the records in ascending order by default. To sort the records in descending order, use the DESC keyword.

  • Like ->

The LIKE operator is used in a WHERE clause to search for a specified pattern in a column. The percent sign (%) represents zero, one, or multiple characters. The underscore sign (_) represents one, single character.

  • Null ->

A field with a NULL value is a field with no value. If a field in a table is optional, it is possible to insert a new record or update a record without adding a value to this field. Then, the field will be saved with a NULL value.

  • Count ->

The COUNT() function returns the number of rows that matches a specified criterion.

  • Distinct ->

The SELECT DISTINCT statement is used to return only distinct (different) values.

Project Description

  1. Bring the customers whose names start with 'a' and surnames start with 'b'.
  2. Count how many different products there are.
  3. Bring the customer_id, first_name, last_name, phone, order_date, order_status and product_name information of the users who bought the 'Electra Cruiser 1 (24-Inch) - 2016' product and who have phone number information, so that the order date is correct.
  4. Sort the products of the 'ELectra' brand in the 'Children Bicycles' category with the 2016-2018 model year by price (brand_name, category_name, product_name, model_year, list_price).
  5. Update the numbers of customers with NULL phone numbers as '0123456789'.

Join, Union, Group by, Having, Exists, Any, All

  • Join ->

A JOIN clause is used to combine rows from two or more tables, based on a related column between them.

  • (INNER) JOIN: Returns records that have matching values in both tables
  • LEFT (OUTER) JOIN: Returns all records from the left table, and the matched records from the right table
  • RIGHT (OUTER) JOIN: Returns all records from the right table, and the matched records from the left table
  • FULL (OUTER) JOIN: Returns all records when there is a match in either left or right table

  • Union ->

The UNION operator is used to combine the result-set of two or more SELECT statements. Every SELECT statement within UNION must have the same number of columns The columns must also have similar data types The columns in every SELECT statement must also be in the same order

  • Group by ->

The GROUP BY statement groups rows that have the same values into summary rows, like "find the number of customers in each country". The GROUP BY statement is often used with aggregate functions (COUNT(), MAX(), MIN(), SUM(), AVG()) to group the result-set by one or more columns.

  • Having ->

The HAVING clause was added to SQL because the WHERE keyword cannot be used with aggregate functions.

  • Exists ->

The EXISTS operator is used to test for the existence of any record in a subquery. The EXISTS operator returns TRUE if the subquery returns one or more records.

  • Any ->

The ANY operator: returns a boolean value as a result, returns TRUE if ANY of the subquery values meet the condition ANY means that the condition will be true if the operation is true for any of the values in the range.

  • All ->

The ALL operator: returns a boolean value as a result returns TRUE if ALL of the subquery values meet the condition is used with SELECT, WHERE and HAVING statements ALL means that the condition will be true only if the operation is true for all values in the range.

Project Description

  1. List all orders with customer and store information.The screen output should include order_id, first_name, last_name and store name.
  2. List the number of all employees under each manager. The screen output should include the staff_id, first_name, last_name and the number of employees belonging to the MANAGER.
  3. List the ones whose surnames end with the letter 'l' for the employees who receive less than 100 orders. The screen output should include the staff_id, first_name, last_name and the total number of orders received by the EMPLOYEE.
  4. List the products with a stock amount greater than 5. The screen output should include product_id, product_name, model_year and list_price.
  5. List any product whose stock is less than 5. The screen output should include product_id, product_name, model_year and list_price.
  6. List any product for which all inventories have a quantity greater than 5. The screen output should include product_id, product_name, model_year and list_price.

View

  • View ->

In SQL, a view is a virtual table based on the result-set of an SQL statement. A view contains rows and columns, just like a real table. The fields in a view are fields from one or more real tables in the database. You can add SQL statements and functions to a view and present the data as if the data were coming from one single table. A view is created with the CREATE VIEW statement.

Project Description

  1. Create the virtual table listing all orders with customer and store information. The screen output should include order_id, first_name, last_name and store name.
  2. Construct the virtual table listing the number of all employees under each manager. Staff_id, first_name, last_name and number of employees belonging to the MANAGER on the screen output must exist.
  3. The virtual table listing those of the employees who receive less than 100 orders and those whose surnames end with the letter 'l'. Staff_id, first_name, last_name and total number of orders received by the EMPLOYEE on the screen output must exist.
  4. Create the virtual table listing the products with a stock amount greater than 5. The screen output should include product_id, product_name, model_year and list_price.
  5. Create the virtual table listing any product with a stock quantity less than 5. The screen output should include product_id, product_name, model_year and list_price.
  6. Virtual table listing any product with all inventories greater than 5. The screen output should include product_id, product_name, model_year and list_price.

Stored Procedures

  • Stored Procedures ->

A stored procedure is a prepared SQL code that you can save, so the code can be reused over and over again. So if you have an SQL query that you write over and over again, save it as a stored procedure, and then just call it to execute it. You can also pass parameters to a stored procedure, so that the stored procedure can act based on the parameter value(s) that is passed.

Project Description

  1. Using the stored procedure structure, bring the employees whose names and surnames begin with the desired letter (first_name, last_name).
  2. Using the stored procedure structure, write the query that sorts the orders with the desired order status and store identifier number in the orders according to the names of the customers (customer_id, first_name, last_name, product_id, email, order_status, store_id).
  3. Using the stored procedure structure, write the query (brand_name, category_name, product_name, model_year, list_price) that sorts the products of the desired brand in the desired category according to the specific model range (minimum-maximum).

Trigger

  • Trigger ->

A trigger is a stored procedure in database which automatically invokes whenever a special event in the database occurs.

Project Description

  1. Create a trigger named “TRG_CustomerCount”. This trigger should print the total number of customers with the name “countOfCustomer” after adding a record to the “tblCustomer” table.
  2. Create a trigger named “TRG_DeletedProduct”. This trigger should print the deleted record after deleting a record from the “tblProduct” table.
  3. Create a trigger named “TRG_DeletedOrder”. This trigger should perform the following two actions after deleting a record from the “tblOrder” table. The record deleted from the “tblOrder” table should be saved in the “tblLoss” table. In this process, pay attention to the information in the "tblLoss" table. The total price on product basis of the records in the “tblLoss” table should be printed on the screen with the name “totalPriceOfLoss”. (Which product was ordered at what price in total.)