mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
658 lines
24 KiB
658 lines
24 KiB
-- Sakila Sample Database Schema |
|
-- Version 1.2 |
|
|
|
-- Copyright (c) 2006, 2019, Oracle and/or its affiliates. |
|
|
|
-- Redistribution and use in source and binary forms, with or without |
|
-- modification, are permitted provided that the following conditions are |
|
-- met: |
|
|
|
-- * Redistributions of source code must retain the above copyright notice, |
|
-- this list of conditions and the following disclaimer. |
|
-- * Redistributions in binary form must reproduce the above copyright |
|
-- notice, this list of conditions and the following disclaimer in the |
|
-- documentation and/or other materials provided with the distribution. |
|
-- * Neither the name of Oracle nor the names of its contributors may be used |
|
-- to endorse or promote products derived from this software without |
|
-- specific prior written permission. |
|
|
|
-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS |
|
-- IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, |
|
-- THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
|
-- PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR |
|
-- CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
|
-- EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
|
-- PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
|
-- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |
|
-- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
|
-- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
|
-- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|
|
|
SET NAMES utf8mb4; |
|
SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0; |
|
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0; |
|
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL'; |
|
|
|
DROP SCHEMA IF EXISTS test_sakila; |
|
CREATE SCHEMA test_sakila; |
|
USE test_sakila; |
|
|
|
-- |
|
-- Table structure for table `actor` |
|
-- |
|
|
|
CREATE TABLE actor ( |
|
actor_id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
first_name VARCHAR(45) NOT NULL, |
|
last_name VARCHAR(45) NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (actor_id), |
|
KEY idx_actor_last_name (last_name) |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `address` |
|
-- |
|
|
|
CREATE TABLE address ( |
|
address_id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
address VARCHAR(50) NOT NULL, |
|
address2 VARCHAR(50) DEFAULT NULL, |
|
district VARCHAR(20) NOT NULL, |
|
city_id SMALLINT UNSIGNED NOT NULL, |
|
postal_code VARCHAR(10) DEFAULT NULL, |
|
phone VARCHAR(20) NOT NULL, |
|
-- Add GEOMETRY column for MySQL 5.7.5 and higher |
|
-- Also include SRID attribute for MySQL 8.0.3 and higher |
|
/*!50705 location GEOMETRY */ /*!80003 SRID 0 */ /*!50705 NOT NULL,*/ |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (address_id), |
|
KEY idx_fk_city_id (city_id), |
|
/*!50705 SPATIAL KEY `idx_location` (location),*/ |
|
CONSTRAINT `fk_address_city` FOREIGN KEY (city_id) REFERENCES city (city_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `category` |
|
-- |
|
|
|
CREATE TABLE category ( |
|
category_id TINYINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
name VARCHAR(25) NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (category_id) |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `city` |
|
-- |
|
|
|
CREATE TABLE city ( |
|
city_id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
city VARCHAR(50) NOT NULL, |
|
country_id SMALLINT UNSIGNED NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (city_id), |
|
KEY idx_fk_country_id (country_id), |
|
CONSTRAINT `fk_city_country` FOREIGN KEY (country_id) REFERENCES country (country_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `country` |
|
-- |
|
|
|
CREATE TABLE country ( |
|
country_id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
country VARCHAR(50) NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (country_id) |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `customer` |
|
-- |
|
|
|
CREATE TABLE customer ( |
|
customer_id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
store_id TINYINT UNSIGNED NOT NULL, |
|
first_name VARCHAR(45) NOT NULL, |
|
last_name VARCHAR(45) NOT NULL, |
|
email VARCHAR(50) DEFAULT NULL, |
|
address_id SMALLINT UNSIGNED NOT NULL, |
|
active BOOLEAN NOT NULL DEFAULT TRUE, |
|
create_date DATETIME NOT NULL, |
|
last_update TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (customer_id), |
|
KEY idx_fk_store_id (store_id), |
|
KEY idx_fk_address_id (address_id), |
|
KEY idx_last_name (last_name), |
|
CONSTRAINT fk_customer_address FOREIGN KEY (address_id) REFERENCES address (address_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_customer_store FOREIGN KEY (store_id) REFERENCES store (store_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `film` |
|
-- |
|
|
|
CREATE TABLE film ( |
|
film_id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
title VARCHAR(128) NOT NULL, |
|
description TEXT DEFAULT NULL, |
|
release_year YEAR DEFAULT NULL, |
|
language_id TINYINT UNSIGNED NOT NULL, |
|
original_language_id TINYINT UNSIGNED DEFAULT NULL, |
|
rental_duration TINYINT UNSIGNED NOT NULL DEFAULT 3, |
|
rental_rate DECIMAL(4,2) NOT NULL DEFAULT 4.99, |
|
length SMALLINT UNSIGNED DEFAULT NULL, |
|
replacement_cost DECIMAL(5,2) NOT NULL DEFAULT 19.99, |
|
rating ENUM('G','PG','PG-13','R','NC-17') DEFAULT 'G', |
|
special_features SET('Trailers','Commentaries','Deleted Scenes','Behind the Scenes') DEFAULT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (film_id), |
|
KEY idx_title (title), |
|
KEY idx_fk_language_id (language_id), |
|
KEY idx_fk_original_language_id (original_language_id), |
|
CONSTRAINT fk_film_language FOREIGN KEY (language_id) REFERENCES language (language_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_film_language_original FOREIGN KEY (original_language_id) REFERENCES language (language_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `film_actor` |
|
-- |
|
|
|
CREATE TABLE film_actor ( |
|
actor_id SMALLINT UNSIGNED NOT NULL, |
|
film_id SMALLINT UNSIGNED NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (actor_id,film_id), |
|
KEY idx_fk_film_id (`film_id`), |
|
CONSTRAINT fk_film_actor_actor FOREIGN KEY (actor_id) REFERENCES actor (actor_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_film_actor_film FOREIGN KEY (film_id) REFERENCES film (film_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `film_category` |
|
-- |
|
|
|
CREATE TABLE film_category ( |
|
film_id SMALLINT UNSIGNED NOT NULL, |
|
category_id TINYINT UNSIGNED NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (film_id, category_id), |
|
CONSTRAINT fk_film_category_film FOREIGN KEY (film_id) REFERENCES film (film_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_film_category_category FOREIGN KEY (category_id) REFERENCES category (category_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `film_text` |
|
-- |
|
-- InnoDB added FULLTEXT support in 5.6.10. If you use an |
|
-- earlier version, then consider upgrading (recommended) or |
|
-- changing InnoDB to MyISAM as the film_text engine |
|
-- |
|
|
|
-- Use InnoDB for film_text as of 5.6.10, MyISAM prior to 5.6.10. |
|
SET @old_default_storage_engine = @@default_storage_engine; |
|
SET @@default_storage_engine = 'MyISAM'; |
|
/*!50610 SET @@default_storage_engine = 'InnoDB'*/; |
|
|
|
CREATE TABLE film_text ( |
|
film_id SMALLINT NOT NULL, |
|
title VARCHAR(255) NOT NULL, |
|
description TEXT, |
|
PRIMARY KEY (film_id), |
|
FULLTEXT KEY idx_title_description (title,description) |
|
) DEFAULT CHARSET=utf8mb4; |
|
|
|
SET @@default_storage_engine = @old_default_storage_engine; |
|
|
|
-- |
|
-- Triggers for loading film_text from film |
|
-- |
|
|
|
CREATE TRIGGER `ins_film` AFTER INSERT ON `film` FOR EACH ROW BEGIN |
|
INSERT INTO film_text (film_id, title, description) |
|
VALUES (new.film_id, new.title, new.description); |
|
END; |
|
|
|
|
|
CREATE TRIGGER `upd_film` AFTER UPDATE ON `film` FOR EACH ROW BEGIN |
|
IF (old.title != new.title) OR (old.description != new.description) OR (old.film_id != new.film_id) |
|
THEN |
|
UPDATE film_text |
|
SET title=new.title, |
|
description=new.description, |
|
film_id=new.film_id |
|
WHERE film_id=old.film_id; |
|
END IF; |
|
END; |
|
|
|
|
|
CREATE TRIGGER `del_film` AFTER DELETE ON `film` FOR EACH ROW BEGIN |
|
DELETE FROM film_text WHERE film_id = old.film_id; |
|
END; |
|
|
|
-- |
|
-- Table structure for table `inventory` |
|
-- |
|
|
|
CREATE TABLE inventory ( |
|
inventory_id MEDIUMINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
film_id SMALLINT UNSIGNED NOT NULL, |
|
store_id TINYINT UNSIGNED NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (inventory_id), |
|
KEY idx_fk_film_id (film_id), |
|
KEY idx_store_id_film_id (store_id,film_id), |
|
CONSTRAINT fk_inventory_store FOREIGN KEY (store_id) REFERENCES store (store_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_inventory_film FOREIGN KEY (film_id) REFERENCES film (film_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `language` |
|
-- |
|
|
|
CREATE TABLE language ( |
|
language_id TINYINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
name CHAR(20) NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (language_id) |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `payment` |
|
-- |
|
|
|
CREATE TABLE payment ( |
|
payment_id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
customer_id SMALLINT UNSIGNED NOT NULL, |
|
staff_id TINYINT UNSIGNED NOT NULL, |
|
rental_id INT DEFAULT NULL, |
|
amount DECIMAL(5,2) NOT NULL, |
|
payment_date DATETIME NOT NULL, |
|
last_update TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (payment_id), |
|
KEY idx_fk_staff_id (staff_id), |
|
KEY idx_fk_customer_id (customer_id), |
|
CONSTRAINT fk_payment_rental FOREIGN KEY (rental_id) REFERENCES rental (rental_id) ON DELETE SET NULL ON UPDATE CASCADE, |
|
CONSTRAINT fk_payment_customer FOREIGN KEY (customer_id) REFERENCES customer (customer_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_payment_staff FOREIGN KEY (staff_id) REFERENCES staff (staff_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
|
|
-- |
|
-- Table structure for table `rental` |
|
-- |
|
|
|
CREATE TABLE rental ( |
|
rental_id INT NOT NULL AUTO_INCREMENT, |
|
rental_date DATETIME NOT NULL, |
|
inventory_id MEDIUMINT UNSIGNED NOT NULL, |
|
customer_id SMALLINT UNSIGNED NOT NULL, |
|
return_date DATETIME DEFAULT NULL, |
|
staff_id TINYINT UNSIGNED NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (rental_id), |
|
UNIQUE KEY (rental_date,inventory_id,customer_id), |
|
KEY idx_fk_inventory_id (inventory_id), |
|
KEY idx_fk_customer_id (customer_id), |
|
KEY idx_fk_staff_id (staff_id), |
|
CONSTRAINT fk_rental_staff FOREIGN KEY (staff_id) REFERENCES staff (staff_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_rental_inventory FOREIGN KEY (inventory_id) REFERENCES inventory (inventory_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_rental_customer FOREIGN KEY (customer_id) REFERENCES customer (customer_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `staff` |
|
-- |
|
|
|
CREATE TABLE staff ( |
|
staff_id TINYINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
first_name VARCHAR(45) NOT NULL, |
|
last_name VARCHAR(45) NOT NULL, |
|
address_id SMALLINT UNSIGNED NOT NULL, |
|
picture BLOB DEFAULT NULL, |
|
email VARCHAR(50) DEFAULT NULL, |
|
store_id TINYINT UNSIGNED NOT NULL, |
|
active BOOLEAN NOT NULL DEFAULT TRUE, |
|
username VARCHAR(16) NOT NULL, |
|
password VARCHAR(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin DEFAULT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (staff_id), |
|
KEY idx_fk_store_id (store_id), |
|
KEY idx_fk_address_id (address_id), |
|
CONSTRAINT fk_staff_store FOREIGN KEY (store_id) REFERENCES store (store_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_staff_address FOREIGN KEY (address_id) REFERENCES address (address_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- Table structure for table `store` |
|
-- |
|
|
|
CREATE TABLE store ( |
|
store_id TINYINT UNSIGNED NOT NULL AUTO_INCREMENT, |
|
manager_staff_id TINYINT UNSIGNED NOT NULL, |
|
address_id SMALLINT UNSIGNED NOT NULL, |
|
last_update TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, |
|
PRIMARY KEY (store_id), |
|
UNIQUE KEY idx_unique_manager (manager_staff_id), |
|
KEY idx_fk_address_id (address_id), |
|
CONSTRAINT fk_store_staff FOREIGN KEY (manager_staff_id) REFERENCES staff (staff_id) ON DELETE RESTRICT ON UPDATE CASCADE, |
|
CONSTRAINT fk_store_address FOREIGN KEY (address_id) REFERENCES address (address_id) ON DELETE RESTRICT ON UPDATE CASCADE |
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; |
|
|
|
-- |
|
-- View structure for view `customer_list` |
|
-- |
|
|
|
CREATE VIEW customer_list |
|
AS |
|
SELECT cu.customer_id AS ID, CONCAT(cu.first_name, _utf8mb4' ', cu.last_name) AS name, a.address AS address, a.postal_code AS `zip code`, |
|
a.phone AS phone, city.city AS city, country.country AS country, IF(cu.active, _utf8mb4'active',_utf8mb4'') AS notes, cu.store_id AS SID |
|
FROM customer AS cu JOIN address AS a ON cu.address_id = a.address_id JOIN city ON a.city_id = city.city_id |
|
JOIN country ON city.country_id = country.country_id; |
|
|
|
-- |
|
-- View structure for view `film_list` |
|
-- |
|
|
|
CREATE VIEW film_list |
|
AS |
|
SELECT film.film_id AS FID, film.title AS title, film.description AS description, category.name AS category, film.rental_rate AS price, |
|
film.length AS length, film.rating AS rating, GROUP_CONCAT(CONCAT(actor.first_name, _utf8mb4' ', actor.last_name) SEPARATOR ', ') AS actors |
|
FROM category LEFT JOIN film_category ON category.category_id = film_category.category_id LEFT JOIN film ON film_category.film_id = film.film_id |
|
JOIN film_actor ON film.film_id = film_actor.film_id |
|
JOIN actor ON film_actor.actor_id = actor.actor_id |
|
GROUP BY film.film_id, category.name; |
|
|
|
-- |
|
-- View structure for view `nicer_but_slower_film_list` |
|
-- |
|
|
|
CREATE VIEW nicer_but_slower_film_list |
|
AS |
|
SELECT film.film_id AS FID, film.title AS title, film.description AS description, category.name AS category, film.rental_rate AS price, |
|
film.length AS length, film.rating AS rating, GROUP_CONCAT(CONCAT(CONCAT(UCASE(SUBSTR(actor.first_name,1,1)), |
|
LCASE(SUBSTR(actor.first_name,2,LENGTH(actor.first_name))),_utf8mb4' ',CONCAT(UCASE(SUBSTR(actor.last_name,1,1)), |
|
LCASE(SUBSTR(actor.last_name,2,LENGTH(actor.last_name)))))) SEPARATOR ', ') AS actors |
|
FROM category LEFT JOIN film_category ON category.category_id = film_category.category_id LEFT JOIN film ON film_category.film_id = film.film_id |
|
JOIN film_actor ON film.film_id = film_actor.film_id |
|
JOIN actor ON film_actor.actor_id = actor.actor_id |
|
GROUP BY film.film_id, category.name; |
|
|
|
-- |
|
-- View structure for view `staff_list` |
|
-- |
|
|
|
CREATE VIEW staff_list |
|
AS |
|
SELECT s.staff_id AS ID, CONCAT(s.first_name, _utf8mb4' ', s.last_name) AS name, a.address AS address, a.postal_code AS `zip code`, a.phone AS phone, |
|
city.city AS city, country.country AS country, s.store_id AS SID |
|
FROM staff AS s JOIN address AS a ON s.address_id = a.address_id JOIN city ON a.city_id = city.city_id |
|
JOIN country ON city.country_id = country.country_id; |
|
|
|
-- |
|
-- View structure for view `sales_by_store` |
|
-- |
|
|
|
CREATE VIEW sales_by_store |
|
AS |
|
SELECT |
|
CONCAT(c.city, _utf8mb4',', cy.country) AS store |
|
, CONCAT(m.first_name, _utf8mb4' ', m.last_name) AS manager |
|
, SUM(p.amount) AS total_sales |
|
FROM payment AS p |
|
INNER JOIN rental AS r ON p.rental_id = r.rental_id |
|
INNER JOIN inventory AS i ON r.inventory_id = i.inventory_id |
|
INNER JOIN store AS s ON i.store_id = s.store_id |
|
INNER JOIN address AS a ON s.address_id = a.address_id |
|
INNER JOIN city AS c ON a.city_id = c.city_id |
|
INNER JOIN country AS cy ON c.country_id = cy.country_id |
|
INNER JOIN staff AS m ON s.manager_staff_id = m.staff_id |
|
GROUP BY s.store_id |
|
ORDER BY cy.country, c.city; |
|
|
|
-- |
|
-- View structure for view `sales_by_film_category` |
|
-- |
|
-- Note that total sales will add up to >100% because |
|
-- some titles belong to more than 1 category |
|
-- |
|
|
|
CREATE VIEW sales_by_film_category |
|
AS |
|
SELECT |
|
c.name AS category |
|
, SUM(p.amount) AS total_sales |
|
FROM payment AS p |
|
INNER JOIN rental AS r ON p.rental_id = r.rental_id |
|
INNER JOIN inventory AS i ON r.inventory_id = i.inventory_id |
|
INNER JOIN film AS f ON i.film_id = f.film_id |
|
INNER JOIN film_category AS fc ON f.film_id = fc.film_id |
|
INNER JOIN category AS c ON fc.category_id = c.category_id |
|
GROUP BY c.name |
|
ORDER BY total_sales DESC; |
|
|
|
-- |
|
-- View structure for view `actor_info` |
|
-- |
|
|
|
CREATE DEFINER=CURRENT_USER SQL SECURITY INVOKER VIEW actor_info |
|
AS |
|
SELECT |
|
a.actor_id, |
|
a.first_name, |
|
a.last_name, |
|
GROUP_CONCAT(DISTINCT CONCAT(c.name, ': ', |
|
(SELECT GROUP_CONCAT(f.title ORDER BY f.title SEPARATOR ', ') |
|
FROM test_sakila.film f |
|
INNER JOIN test_sakila.film_category fc |
|
ON f.film_id = fc.film_id |
|
INNER JOIN test_sakila.film_actor fa |
|
ON f.film_id = fa.film_id |
|
WHERE fc.category_id = c.category_id |
|
AND fa.actor_id = a.actor_id |
|
) |
|
) |
|
ORDER BY c.name SEPARATOR '; ') |
|
AS film_info |
|
FROM test_sakila.actor a |
|
LEFT JOIN test_sakila.film_actor fa |
|
ON a.actor_id = fa.actor_id |
|
LEFT JOIN test_sakila.film_category fc |
|
ON fa.film_id = fc.film_id |
|
LEFT JOIN test_sakila.category c |
|
ON fc.category_id = c.category_id |
|
GROUP BY a.actor_id, a.first_name, a.last_name; |
|
|
|
-- |
|
-- Procedure structure for procedure `rewards_report` |
|
-- |
|
|
|
CREATE PROCEDURE rewards_report ( |
|
IN min_monthly_purchases TINYINT UNSIGNED |
|
, IN min_dollar_amount_purchased DECIMAL(10,2) |
|
, OUT count_rewardees INT |
|
) |
|
LANGUAGE SQL |
|
NOT DETERMINISTIC |
|
READS SQL DATA |
|
SQL SECURITY DEFINER |
|
COMMENT 'Provides a customizable report on best customers' |
|
proc: BEGIN |
|
|
|
DECLARE last_month_start DATE; |
|
DECLARE last_month_end DATE; |
|
|
|
/* Some sanity checks... */ |
|
IF min_monthly_purchases = 0 THEN |
|
SELECT 'Minimum monthly purchases parameter must be > 0'; |
|
LEAVE proc; |
|
END IF; |
|
IF min_dollar_amount_purchased = 0.00 THEN |
|
SELECT 'Minimum monthly dollar amount purchased parameter must be > $0.00'; |
|
LEAVE proc; |
|
END IF; |
|
|
|
/* Determine start and end time periods */ |
|
SET last_month_start = DATE_SUB(CURRENT_DATE(), INTERVAL 1 MONTH); |
|
SET last_month_start = STR_TO_DATE(CONCAT(YEAR(last_month_start),'-',MONTH(last_month_start),'-01'),'%Y-%m-%d'); |
|
SET last_month_end = LAST_DAY(last_month_start); |
|
|
|
/* |
|
Create a temporary storage area for |
|
Customer IDs. |
|
*/ |
|
CREATE TEMPORARY TABLE tmpCustomer (customer_id SMALLINT UNSIGNED NOT NULL PRIMARY KEY); |
|
|
|
/* |
|
Find all customers meeting the |
|
monthly purchase requirements |
|
*/ |
|
INSERT INTO tmpCustomer (customer_id) |
|
SELECT p.customer_id |
|
FROM payment AS p |
|
WHERE DATE(p.payment_date) BETWEEN last_month_start AND last_month_end |
|
GROUP BY customer_id |
|
HAVING SUM(p.amount) > min_dollar_amount_purchased |
|
AND COUNT(customer_id) > min_monthly_purchases; |
|
|
|
/* Populate OUT parameter with count of found customers */ |
|
SELECT COUNT(*) FROM tmpCustomer INTO count_rewardees; |
|
|
|
/* |
|
Output ALL customer information of matching rewardees. |
|
Customize output as needed. |
|
*/ |
|
SELECT c.* |
|
FROM tmpCustomer AS t |
|
INNER JOIN customer AS c ON t.customer_id = c.customer_id; |
|
|
|
/* Clean up */ |
|
DROP TABLE tmpCustomer; |
|
END; |
|
|
|
CREATE FUNCTION get_customer_balance(p_customer_id INT, p_effective_date DATETIME) RETURNS DECIMAL(5,2) |
|
DETERMINISTIC |
|
READS SQL DATA |
|
BEGIN |
|
|
|
#OK, WE NEED TO CALCULATE THE CURRENT BALANCE GIVEN A CUSTOMER_ID AND A DATE |
|
#THAT WE WANT THE BALANCE TO BE EFFECTIVE FOR. THE BALANCE IS: |
|
# 1) RENTAL FEES FOR ALL PREVIOUS RENTALS |
|
# 2) ONE DOLLAR FOR EVERY DAY THE PREVIOUS RENTALS ARE OVERDUE |
|
# 3) IF A FILM IS MORE THAN RENTAL_DURATION * 2 OVERDUE, CHARGE THE REPLACEMENT_COST |
|
# 4) SUBTRACT ALL PAYMENTS MADE BEFORE THE DATE SPECIFIED |
|
|
|
DECLARE v_rentfees DECIMAL(5,2); #FEES PAID TO RENT THE VIDEOS INITIALLY |
|
DECLARE v_overfees INTEGER; #LATE FEES FOR PRIOR RENTALS |
|
DECLARE v_payments DECIMAL(5,2); #SUM OF PAYMENTS MADE PREVIOUSLY |
|
|
|
SELECT IFNULL(SUM(film.rental_rate),0) INTO v_rentfees |
|
FROM film, inventory, rental |
|
WHERE film.film_id = inventory.film_id |
|
AND inventory.inventory_id = rental.inventory_id |
|
AND rental.rental_date <= p_effective_date |
|
AND rental.customer_id = p_customer_id; |
|
|
|
SELECT IFNULL(SUM(IF((TO_DAYS(rental.return_date) - TO_DAYS(rental.rental_date)) > film.rental_duration, |
|
((TO_DAYS(rental.return_date) - TO_DAYS(rental.rental_date)) - film.rental_duration),0)),0) INTO v_overfees |
|
FROM rental, inventory, film |
|
WHERE film.film_id = inventory.film_id |
|
AND inventory.inventory_id = rental.inventory_id |
|
AND rental.rental_date <= p_effective_date |
|
AND rental.customer_id = p_customer_id; |
|
|
|
|
|
SELECT IFNULL(SUM(payment.amount),0) INTO v_payments |
|
FROM payment |
|
|
|
WHERE payment.payment_date <= p_effective_date |
|
AND payment.customer_id = p_customer_id; |
|
|
|
RETURN v_rentfees + v_overfees - v_payments; |
|
END; |
|
|
|
CREATE PROCEDURE film_in_stock(IN p_film_id INT, IN p_store_id INT, OUT p_film_count INT) |
|
READS SQL DATA |
|
BEGIN |
|
SELECT inventory_id |
|
FROM inventory |
|
WHERE film_id = p_film_id |
|
AND store_id = p_store_id |
|
AND inventory_in_stock(inventory_id); |
|
|
|
SELECT COUNT(*) |
|
FROM inventory |
|
WHERE film_id = p_film_id |
|
AND store_id = p_store_id |
|
AND inventory_in_stock(inventory_id) |
|
INTO p_film_count; |
|
END; |
|
|
|
CREATE PROCEDURE film_not_in_stock(IN p_film_id INT, IN p_store_id INT, OUT p_film_count INT) |
|
READS SQL DATA |
|
BEGIN |
|
SELECT inventory_id |
|
FROM inventory |
|
WHERE film_id = p_film_id |
|
AND store_id = p_store_id |
|
AND NOT inventory_in_stock(inventory_id); |
|
|
|
SELECT COUNT(*) |
|
FROM inventory |
|
WHERE film_id = p_film_id |
|
AND store_id = p_store_id |
|
AND NOT inventory_in_stock(inventory_id) |
|
INTO p_film_count; |
|
END; |
|
|
|
|
|
CREATE FUNCTION inventory_held_by_customer(p_inventory_id INT) RETURNS INT |
|
READS SQL DATA |
|
BEGIN |
|
DECLARE v_customer_id INT; |
|
DECLARE EXIT HANDLER FOR NOT FOUND RETURN NULL; |
|
|
|
SELECT customer_id INTO v_customer_id |
|
FROM rental |
|
WHERE return_date IS NULL |
|
AND inventory_id = p_inventory_id; |
|
|
|
RETURN v_customer_id; |
|
END; |
|
|
|
CREATE FUNCTION inventory_in_stock(p_inventory_id INT) RETURNS BOOLEAN |
|
READS SQL DATA |
|
BEGIN |
|
DECLARE v_rentals INT; |
|
DECLARE v_out INT; |
|
|
|
#AN ITEM IS IN-STOCK IF THERE ARE EITHER NO ROWS IN THE rental TABLE |
|
#FOR THE ITEM OR ALL ROWS HAVE return_date POPULATED |
|
|
|
SELECT COUNT(*) INTO v_rentals |
|
FROM rental |
|
WHERE inventory_id = p_inventory_id; |
|
|
|
IF v_rentals = 0 THEN |
|
RETURN TRUE; |
|
END IF; |
|
|
|
SELECT COUNT(rental_id) INTO v_out |
|
FROM inventory LEFT JOIN rental USING(inventory_id) |
|
WHERE inventory.inventory_id = p_inventory_id |
|
AND rental.return_date IS NULL; |
|
|
|
IF v_out > 0 THEN |
|
RETURN FALSE; |
|
ELSE |
|
RETURN TRUE; |
|
END IF; |
|
END; |
|
|
|
SET SQL_MODE=@OLD_SQL_MODE; |
|
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS; |
|
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS; |
|
|
|
|
|
|