-- ==========================================
-- SCRIPT DE CREATION DE LA BDD DU TP7 BDD ( Sub- Queries) - EMSI
-- Préparé par Pr. BOUKHDIR
-- 11 May 2026
-- ==========================================
DROP DATABASE IF EXISTS gestion_commerciale;
CREATE DATABASE gestion_commerciale;
USE gestion_commerciale;
-- ==========================================
-- SUPPRESSION DES TABLES
-- ==========================================
DROP TABLE IF EXISTS Approvisionnement;
DROP TABLE IF EXISTS Fournisseur;
DROP TABLE IF EXISTS Ligne_Commande;
DROP TABLE IF EXISTS Commande;
DROP TABLE IF EXISTS Client;
DROP TABLE IF EXISTS Produit;
DROP TABLE IF EXISTS Categorie;
-- ==========================================
-- CREATION DES TABLES
-- ==========================================
CREATE TABLE Categorie (
id_cat INT PRIMARY KEY,
nom_cat VARCHAR( 50 ) UNIQUE NOT NULL,
description TEXT
) ;
CREATE TABLE Produit (
id_prod INT PRIMARY KEY,
nom_prod VARCHAR( 50 ) NOT NULL,
prix DECIMAL( 10 , 2 ) CHECK ( prix > 0 ) ,
stock INT CHECK ( stock >= 0 ) ,
id_cat INT,
FOREIGN KEY ( id_cat) REFERENCES Categorie( id_cat)
) ;
CREATE TABLE Client (
id_client INT PRIMARY KEY,
nom VARCHAR( 50 ) NOT NULL,
prenom VARCHAR( 50 ) NOT NULL,
email VARCHAR( 100 ) UNIQUE NOT NULL,
ville VARCHAR( 50 )
) ;
CREATE TABLE Commande (
id_cmd INT PRIMARY KEY,
date_cmd DATE NOT NULL,
statut VARCHAR( 20 ) DEFAULT 'En cours' ,
id_client INT,
FOREIGN KEY ( id_client) REFERENCES Client( id_client)
) ;
CREATE TABLE Ligne_Commande (
id_cmd INT,
id_prod INT,
quantite INT CHECK ( quantite > 0 ) ,
PRIMARY KEY ( id_cmd, id_prod) ,
FOREIGN KEY ( id_cmd) REFERENCES Commande( id_cmd) ,
FOREIGN KEY ( id_prod) REFERENCES Produit( id_prod)
) ;
CREATE TABLE Fournisseur (
id_fourn INT PRIMARY KEY,
nom_fourn VARCHAR( 50 ) NOT NULL,
ville VARCHAR( 50 ) ,
telephone VARCHAR( 20 ) UNIQUE
) ;
CREATE TABLE Approvisionnement (
id_appro INT PRIMARY KEY,
date_appro DATE NOT NULL,
qte INT CHECK ( qte > 0 ) ,
id_prod INT,
id_fourn INT,
FOREIGN KEY ( id_prod) REFERENCES Produit( id_prod) ,
FOREIGN KEY ( id_fourn) REFERENCES Fournisseur( id_fourn)
) ;
-- ==========================================
-- INSERTION DES CATEGORIES
-- ==========================================
INSERT INTO Categorie VALUES
( 1 , 'Informatique' , 'Ordinateurs et peripheriques' ) ,
( 2 , 'Bureautique' , 'Materiel de bureau' ) ,
( 3 , 'Mobilier' , 'Mobilier informatique' ) ,
( 4 , 'Reseau' , 'Equipements reseau' ) ,
( 5 , 'Composants' , 'Pieces hardware' ) ,
( 6 , 'Accessoires' , 'Accessoires divers' ) ,
( 7 , 'Audio' , 'Materiel audio' ) ,
( 8 , 'Video' , 'Materiel video' ) ,
( 9 , 'Logiciels' , 'Applications et licences' ) ,
( 10 , 'Vide' , 'Categorie vide' ) ;
-- ==========================================
-- INSERTION DES PRODUITS
-- ==========================================
INSERT INTO Produit VALUES
( 1 , 'Clavier Mecanique' , 120.00 , 50 , 1 ) ,
( 2 , 'Souris sans fil' , 45.00 , 100 , 1 ) ,
( 3 , 'Ecran LED' , 300.00 , 0 , 8 ) ,
( 4 , 'Cable HDMI' , 15.00 , 200 , 6 ) ,
( 5 , 'Chaise Ergonomique' , 450.00 , 20 , 3 ) ,
( 6 , 'Bureau Gamer' , 600.00 , 15 , 3 ) ,
( 7 , 'Routeur WiFi' , 80.00 , 30 , 4 ) ,
( 8 , 'Casque Audio' , 150.00 , 40 , 7 ) ,
( 9 , 'Webcam HD' , 60.00 , 0 , 8 ) ,
( 10 , 'Produit A' , 25.00 , 100 , 6 ) ,
( 11 , 'Imprimante Laser' , 150.00 , 15 , 2 ) ,
( 12 , 'Ramette Papier' , 5.00 , 500 , 2 ) ,
( 13 , 'Cle USB 64Go' , 10.00 , 300 , 1 ) ,
( 14 , 'Produit Jamais Commande' , 50.00 , 10 , 1 ) ,
( 20 , 'Produit B' , 30.00 , 50 , 6 ) ;
-- ==========================================
-- INSERTION DES CLIENTS
-- ==========================================
INSERT INTO Client VALUES
( 1 , 'El Idrissi' , 'Yassine' , 'yassine.elidrissi@mail.com' , 'Midelt' ) ,
( 2 , 'Alaoui' , 'Salma' , 'salma.alaoui@mail.com' , 'Souk Laarbaa' ) ,
( 3 , 'Benjelloun' , 'Imane' , 'imane.benjelloun@mail.com' , 'Imlil' ) ,
( 4 , 'Tahiri' , 'Hamza' , 'hamza.tahiri@mail.com' , 'Tabant' ) ,
( 5 , 'Berrada' , 'Siham' , 'siham.berrada@mail.com' , 'Tioumliline' ) ,
( 6 , 'Amrani' , 'Zakaria' , 'zakaria.amrani@mail.com' , 'Ain Taoujtat' ) ,
( 7 , 'Skalli' , 'Nadia' , 'nadia.skalli@mail.com' , 'Badis' ) ,
( 8 , 'Lahlou' , 'Karim' , 'karim.lahlou@mail.com' , 'Louizia' ) ,
( 9 , 'Tazi' , 'Meriem' , 'meriem.tazi@mail.com' , 'Khmis Louta' ) ,
( 10 , 'Inactive' , 'Client' , 'inactive@mail.com' , 'Oud Kennar' ) ;
-- ==========================================
-- INSERTION DES COMMANDES
-- ==========================================
INSERT INTO Commande VALUES
( 1 , '2023-01-15' , 'Livree' , 3 ) ,
( 2 , '2023-02-20' , 'Livree' , 1 ) ,
( 3 , '2023-03-10' , 'Livree' , 2 ) ,
( 4 , '2024-01-05' , 'En cours' , 3 ) ,
( 5 , '2024-02-15' , 'Livree' , 4 ) ,
( 6 , '2024-03-20' , 'Expediee' , 1 ) ,
( 7 , '2024-04-10' , 'En cours' , 2 ) ,
( 8 , '2024-05-01' , 'Livree' , 7 ) ,
( 9 , '2024-06-15' , 'En cours' , 8 ) ,
( 10 , '2024-07-20' , 'En cours' , 9 ) ;
-- ==========================================
-- INSERTION DES LIGNES COMMANDES
-- ==========================================
INSERT INTO Ligne_Commande VALUES
( 1 , 1 , 2 ) ,
( 2 , 3 , 1 ) ,
( 3 , 5 , 1 ) ,
( 4 , 4 , 3 ) ,
( 5 , 11 , 2 ) ,
( 6 , 10 , 1 ) ,
( 7 , 20 , 1 ) ,
( 8 , 6 , 1 ) ,
( 9 , 10 , 15 ) ,
( 10 , 2 , 1 ) ,
( 1 , 10 , 1 ) ,
( 2 , 5 , 1 ) ,
( 3 , 10 , 1 ) ;
-- ==========================================
-- INSERTION DES FOURNISSEURS
-- ==========================================
INSERT INTO Fournisseur VALUES
( 1 , 'AtlasTech' , 'Midelt' , '0611111111' ) ,
( 2 , 'MaghrebSupply' , 'Souk Laarbaa' , '0622222222' ) ,
( 3 , 'NordicInfo' , 'Imlil' , '0633333333' ) ,
( 4 , 'SaharaDistrib' , 'Tabant' , '0644444444' ) ,
( 5 , 'HighTech Maroc' , 'Tioumliline' , '0655555555' ) ,
( 6 , 'DigitalNet' , 'Ain Taoujtat' , '0666666666' ) ,
( 7 , 'SmartPro' , 'Badis' , '0677777777' ) ,
( 8 , 'FutureTech' , 'Louizia' , '0688888888' ) ,
( 9 , 'InactiveFourn' , 'Oud Kennar' , '0699999999' ) ,
( 10 , 'CyberEquip' , 'Khmis Louta' , '0600000000' ) ;
-- ==========================================
-- INSERTION DES APPROVISIONNEMENTS
-- ==========================================
INSERT INTO Approvisionnement VALUES
( 1 , '2023-01-10' , 50 , 1 , 1 ) ,
( 2 , '2023-02-15' , 100 , 2 , 1 ) ,
( 3 , '2023-03-20' , 200 , 4 , 2 ) ,
( 4 , '2023-04-25' , 15 , 6 , 3 ) ,
( 5 , '2024-01-10' , 30 , 7 , 4 ) ,
( 6 , '2024-02-15' , 40 , 8 , 5 ) ,
( 7 , '2024-03-20' , 100 , 10 , 1 ) ,
( 8 , '2024-04-25' , 50 , 20 , 2 ) ,
( 9 , '2024-05-10' , 10 , 3 , 1 ) ,
( 10 , '2024-06-15' , 15 , 11 , 4 ) ;
COMMIT;
LS0gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tIFNDUklQVCBERSBDUkVBVElPTiBERSBMQSBCREQgRFUgVFA3IEJERCAoU3ViLVF1ZXJpZXMpIC1FTVNJCi0tIFByw6lwYXLDqSBwYXIgUHIuIEJPVUtIRElSCi0tIDExIE1heSAyMDI2Ci0tID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKRFJPUCBEQVRBQkFTRSBJRiBFWElTVFMgZ2VzdGlvbl9jb21tZXJjaWFsZTsKQ1JFQVRFIERBVEFCQVNFIGdlc3Rpb25fY29tbWVyY2lhbGU7ClVTRSBnZXN0aW9uX2NvbW1lcmNpYWxlOwoKLS0gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tIFNVUFBSRVNTSU9OIERFUyBUQUJMRVMKLS0gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpEUk9QIFRBQkxFIElGIEVYSVNUUyBBcHByb3Zpc2lvbm5lbWVudDsKRFJPUCBUQUJMRSBJRiBFWElTVFMgRm91cm5pc3NldXI7CkRST1AgVEFCTEUgSUYgRVhJU1RTIExpZ25lX0NvbW1hbmRlOwpEUk9QIFRBQkxFIElGIEVYSVNUUyBDb21tYW5kZTsKRFJPUCBUQUJMRSBJRiBFWElTVFMgQ2xpZW50OwpEUk9QIFRBQkxFIElGIEVYSVNUUyBQcm9kdWl0OwpEUk9QIFRBQkxFIElGIEVYSVNUUyBDYXRlZ29yaWU7CgotLSA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KLS0gQ1JFQVRJT04gREVTIFRBQkxFUwotLSA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCkNSRUFURSBUQUJMRSBDYXRlZ29yaWUgKAogICAgaWRfY2F0IElOVCBQUklNQVJZIEtFWSwKICAgIG5vbV9jYXQgVkFSQ0hBUig1MCkgVU5JUVVFIE5PVCBOVUxMLAogICAgZGVzY3JpcHRpb24gVEVYVAopOwoKQ1JFQVRFIFRBQkxFIFByb2R1aXQgKAogICAgaWRfcHJvZCBJTlQgUFJJTUFSWSBLRVksCiAgICBub21fcHJvZCBWQVJDSEFSKDUwKSBOT1QgTlVMTCwKICAgIHByaXggREVDSU1BTCgxMCwyKSBDSEVDSyAocHJpeCA+IDApLAogICAgc3RvY2sgSU5UIENIRUNLIChzdG9jayA+PSAwKSwKICAgIGlkX2NhdCBJTlQsCiAgICBGT1JFSUdOIEtFWSAoaWRfY2F0KSBSRUZFUkVOQ0VTIENhdGVnb3JpZShpZF9jYXQpCik7CgpDUkVBVEUgVEFCTEUgQ2xpZW50ICgKICAgIGlkX2NsaWVudCBJTlQgUFJJTUFSWSBLRVksCiAgICBub20gVkFSQ0hBUig1MCkgTk9UIE5VTEwsCiAgICBwcmVub20gVkFSQ0hBUig1MCkgTk9UIE5VTEwsCiAgICBlbWFpbCBWQVJDSEFSKDEwMCkgVU5JUVVFIE5PVCBOVUxMLAogICAgdmlsbGUgVkFSQ0hBUig1MCkKKTsKCkNSRUFURSBUQUJMRSBDb21tYW5kZSAoCiAgICBpZF9jbWQgSU5UIFBSSU1BUlkgS0VZLAogICAgZGF0ZV9jbWQgREFURSBOT1QgTlVMTCwKICAgIHN0YXR1dCBWQVJDSEFSKDIwKSBERUZBVUxUICdFbiBjb3VycycsCiAgICBpZF9jbGllbnQgSU5ULAogICAgRk9SRUlHTiBLRVkgKGlkX2NsaWVudCkgUkVGRVJFTkNFUyBDbGllbnQoaWRfY2xpZW50KQopOwoKQ1JFQVRFIFRBQkxFIExpZ25lX0NvbW1hbmRlICgKICAgIGlkX2NtZCBJTlQsCiAgICBpZF9wcm9kIElOVCwKICAgIHF1YW50aXRlIElOVCBDSEVDSyAocXVhbnRpdGUgPiAwKSwKICAgIFBSSU1BUlkgS0VZIChpZF9jbWQsIGlkX3Byb2QpLAogICAgRk9SRUlHTiBLRVkgKGlkX2NtZCkgUkVGRVJFTkNFUyBDb21tYW5kZShpZF9jbWQpLAogICAgRk9SRUlHTiBLRVkgKGlkX3Byb2QpIFJFRkVSRU5DRVMgUHJvZHVpdChpZF9wcm9kKQopOwoKQ1JFQVRFIFRBQkxFIEZvdXJuaXNzZXVyICgKICAgIGlkX2ZvdXJuIElOVCBQUklNQVJZIEtFWSwKICAgIG5vbV9mb3VybiBWQVJDSEFSKDUwKSBOT1QgTlVMTCwKICAgIHZpbGxlIFZBUkNIQVIoNTApLAogICAgdGVsZXBob25lIFZBUkNIQVIoMjApIFVOSVFVRQopOwoKQ1JFQVRFIFRBQkxFIEFwcHJvdmlzaW9ubmVtZW50ICgKICAgIGlkX2FwcHJvIElOVCBQUklNQVJZIEtFWSwKICAgIGRhdGVfYXBwcm8gREFURSBOT1QgTlVMTCwKICAgIHF0ZSBJTlQgQ0hFQ0sgKHF0ZSA+IDApLAogICAgaWRfcHJvZCBJTlQsCiAgICBpZF9mb3VybiBJTlQsCiAgICBGT1JFSUdOIEtFWSAoaWRfcHJvZCkgUkVGRVJFTkNFUyBQcm9kdWl0KGlkX3Byb2QpLAogICAgRk9SRUlHTiBLRVkgKGlkX2ZvdXJuKSBSRUZFUkVOQ0VTIEZvdXJuaXNzZXVyKGlkX2ZvdXJuKQopOwoKLS0gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tIElOU0VSVElPTiBERVMgQ0FURUdPUklFUwotLSA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KCklOU0VSVCBJTlRPIENhdGVnb3JpZSBWQUxVRVMKKDEsICdJbmZvcm1hdGlxdWUnLCAnT3JkaW5hdGV1cnMgZXQgcGVyaXBoZXJpcXVlcycpLAooMiwgJ0J1cmVhdXRpcXVlJywgJ01hdGVyaWVsIGRlIGJ1cmVhdScpLAooMywgJ01vYmlsaWVyJywgJ01vYmlsaWVyIGluZm9ybWF0aXF1ZScpLAooNCwgJ1Jlc2VhdScsICdFcXVpcGVtZW50cyByZXNlYXUnKSwKKDUsICdDb21wb3NhbnRzJywgJ1BpZWNlcyBoYXJkd2FyZScpLAooNiwgJ0FjY2Vzc29pcmVzJywgJ0FjY2Vzc29pcmVzIGRpdmVycycpLAooNywgJ0F1ZGlvJywgJ01hdGVyaWVsIGF1ZGlvJyksCig4LCAnVmlkZW8nLCAnTWF0ZXJpZWwgdmlkZW8nKSwKKDksICdMb2dpY2llbHMnLCAnQXBwbGljYXRpb25zIGV0IGxpY2VuY2VzJyksCigxMCwgJ1ZpZGUnLCAnQ2F0ZWdvcmllIHZpZGUnKTsKCi0tID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQotLSBJTlNFUlRJT04gREVTIFBST0RVSVRTCi0tID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKSU5TRVJUIElOVE8gUHJvZHVpdCBWQUxVRVMKKDEsICdDbGF2aWVyIE1lY2FuaXF1ZScsIDEyMC4wMCwgNTAsIDEpLAooMiwgJ1NvdXJpcyBzYW5zIGZpbCcsIDQ1LjAwLCAxMDAsIDEpLAooMywgJ0VjcmFuIExFRCcsIDMwMC4wMCwgMCwgOCksCig0LCAnQ2FibGUgSERNSScsIDE1LjAwLCAyMDAsIDYpLAooNSwgJ0NoYWlzZSBFcmdvbm9taXF1ZScsIDQ1MC4wMCwgMjAsIDMpLAooNiwgJ0J1cmVhdSBHYW1lcicsIDYwMC4wMCwgMTUsIDMpLAooNywgJ1JvdXRldXIgV2lGaScsIDgwLjAwLCAzMCwgNCksCig4LCAnQ2FzcXVlIEF1ZGlvJywgMTUwLjAwLCA0MCwgNyksCig5LCAnV2ViY2FtIEhEJywgNjAuMDAsIDAsIDgpLAooMTAsICdQcm9kdWl0IEEnLCAyNS4wMCwgMTAwLCA2KSwKKDExLCAnSW1wcmltYW50ZSBMYXNlcicsIDE1MC4wMCwgMTUsIDIpLAooMTIsICdSYW1ldHRlIFBhcGllcicsIDUuMDAsIDUwMCwgMiksCigxMywgJ0NsZSBVU0IgNjRHbycsIDEwLjAwLCAzMDAsIDEpLAooMTQsICdQcm9kdWl0IEphbWFpcyBDb21tYW5kZScsIDUwLjAwLCAxMCwgMSksCigyMCwgJ1Byb2R1aXQgQicsIDMwLjAwLCA1MCwgNik7CgotLSA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KLS0gSU5TRVJUSU9OIERFUyBDTElFTlRTCi0tID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKSU5TRVJUIElOVE8gQ2xpZW50IFZBTFVFUwooMSwgJ0VsIElkcmlzc2knLCAnWWFzc2luZScsICd5YXNzaW5lLmVsaWRyaXNzaUBtYWlsLmNvbScsICdNaWRlbHQnKSwKKDIsICdBbGFvdWknLCAnU2FsbWEnLCAnc2FsbWEuYWxhb3VpQG1haWwuY29tJywgJ1NvdWsgTGFhcmJhYScpLAooMywgJ0JlbmplbGxvdW4nLCAnSW1hbmUnLCAnaW1hbmUuYmVuamVsbG91bkBtYWlsLmNvbScsICdJbWxpbCcpLAooNCwgJ1RhaGlyaScsICdIYW16YScsICdoYW16YS50YWhpcmlAbWFpbC5jb20nLCAnVGFiYW50JyksCig1LCAnQmVycmFkYScsICdTaWhhbScsICdzaWhhbS5iZXJyYWRhQG1haWwuY29tJywgJ1Rpb3VtbGlsaW5lJyksCig2LCAnQW1yYW5pJywgJ1pha2FyaWEnLCAnemFrYXJpYS5hbXJhbmlAbWFpbC5jb20nLCAnQWluIFRhb3VqdGF0JyksCig3LCAnU2thbGxpJywgJ05hZGlhJywgJ25hZGlhLnNrYWxsaUBtYWlsLmNvbScsICdCYWRpcycpLAooOCwgJ0xhaGxvdScsICdLYXJpbScsICdrYXJpbS5sYWhsb3VAbWFpbC5jb20nLCAnTG91aXppYScpLAooOSwgJ1RhemknLCAnTWVyaWVtJywgJ21lcmllbS50YXppQG1haWwuY29tJywgJ0tobWlzIExvdXRhJyksCigxMCwgJ0luYWN0aXZlJywgJ0NsaWVudCcsICdpbmFjdGl2ZUBtYWlsLmNvbScsICdPdWQgS2VubmFyJyk7CgotLSA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KLS0gSU5TRVJUSU9OIERFUyBDT01NQU5ERVMKLS0gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CgpJTlNFUlQgSU5UTyBDb21tYW5kZSBWQUxVRVMKKDEsICcyMDIzLTAxLTE1JywgJ0xpdnJlZScsIDMpLAooMiwgJzIwMjMtMDItMjAnLCAnTGl2cmVlJywgMSksCigzLCAnMjAyMy0wMy0xMCcsICdMaXZyZWUnLCAyKSwKKDQsICcyMDI0LTAxLTA1JywgJ0VuIGNvdXJzJywgMyksCig1LCAnMjAyNC0wMi0xNScsICdMaXZyZWUnLCA0KSwKKDYsICcyMDI0LTAzLTIwJywgJ0V4cGVkaWVlJywgMSksCig3LCAnMjAyNC0wNC0xMCcsICdFbiBjb3VycycsIDIpLAooOCwgJzIwMjQtMDUtMDEnLCAnTGl2cmVlJywgNyksCig5LCAnMjAyNC0wNi0xNScsICdFbiBjb3VycycsIDgpLAooMTAsICcyMDI0LTA3LTIwJywgJ0VuIGNvdXJzJywgOSk7CgotLSA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KLS0gSU5TRVJUSU9OIERFUyBMSUdORVMgQ09NTUFOREVTCi0tID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKSU5TRVJUIElOVE8gTGlnbmVfQ29tbWFuZGUgVkFMVUVTCigxLCAxLCAyKSwKKDIsIDMsIDEpLAooMywgNSwgMSksCig0LCA0LCAzKSwKKDUsIDExLCAyKSwKKDYsIDEwLCAxKSwKKDcsIDIwLCAxKSwKKDgsIDYsIDEpLAooOSwgMTAsIDE1KSwKKDEwLCAyLCAxKSwKKDEsIDEwLCAxKSwKKDIsIDUsIDEpLAooMywgMTAsIDEpOwoKLS0gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tIElOU0VSVElPTiBERVMgRk9VUk5JU1NFVVJTCi0tID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKSU5TRVJUIElOVE8gRm91cm5pc3NldXIgVkFMVUVTCigxLCAnQXRsYXNUZWNoJywgJ01pZGVsdCcsICcwNjExMTExMTExJyksCigyLCAnTWFnaHJlYlN1cHBseScsICdTb3VrIExhYXJiYWEnLCAnMDYyMjIyMjIyMicpLAooMywgJ05vcmRpY0luZm8nLCAnSW1saWwnLCAnMDYzMzMzMzMzMycpLAooNCwgJ1NhaGFyYURpc3RyaWInLCAnVGFiYW50JywgJzA2NDQ0NDQ0NDQnKSwKKDUsICdIaWdoVGVjaCBNYXJvYycsICdUaW91bWxpbGluZScsICcwNjU1NTU1NTU1JyksCig2LCAnRGlnaXRhbE5ldCcsICdBaW4gVGFvdWp0YXQnLCAnMDY2NjY2NjY2NicpLAooNywgJ1NtYXJ0UHJvJywgJ0JhZGlzJywgJzA2Nzc3Nzc3NzcnKSwKKDgsICdGdXR1cmVUZWNoJywgJ0xvdWl6aWEnLCAnMDY4ODg4ODg4OCcpLAooOSwgJ0luYWN0aXZlRm91cm4nLCAnT3VkIEtlbm5hcicsICcwNjk5OTk5OTk5JyksCigxMCwgJ0N5YmVyRXF1aXAnLCAnS2htaXMgTG91dGEnLCAnMDYwMDAwMDAwMCcpOwoKLS0gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tIElOU0VSVElPTiBERVMgQVBQUk9WSVNJT05ORU1FTlRTCi0tID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKSU5TRVJUIElOVE8gQXBwcm92aXNpb25uZW1lbnQgVkFMVUVTCigxLCAnMjAyMy0wMS0xMCcsIDUwLCAxLCAxKSwKKDIsICcyMDIzLTAyLTE1JywgMTAwLCAyLCAxKSwKKDMsICcyMDIzLTAzLTIwJywgMjAwLCA0LCAyKSwKKDQsICcyMDIzLTA0LTI1JywgMTUsIDYsIDMpLAooNSwgJzIwMjQtMDEtMTAnLCAzMCwgNywgNCksCig2LCAnMjAyNC0wMi0xNScsIDQwLCA4LCA1KSwKKDcsICcyMDI0LTAzLTIwJywgMTAwLCAxMCwgMSksCig4LCAnMjAyNC0wNC0yNScsIDUwLCAyMCwgMiksCig5LCAnMjAyNC0wNS0xMCcsIDEwLCAzLCAxKSwKKDEwLCAnMjAyNC0wNi0xNScsIDE1LCAxMSwgNCk7CgpDT01NSVQ7