-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabaseCreationCode.sql
More file actions
149 lines (118 loc) · 5.46 KB
/
databaseCreationCode.sql
File metadata and controls
149 lines (118 loc) · 5.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
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,ALLOW_INVALID_DATES';
-- -----------------------------------------------------
-- Schema bd_sweepstake
-- -----------------------------------------------------
CREATE SCHEMA IF NOT EXISTS `bd_sweepstake` DEFAULT CHARACTER SET utf8 ;
USE `bd_sweepstake` ;
-- -----------------------------------------------------
-- Table `bd_sweepstake`.`teams`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `bd_sweepstake`.`teams` (
`idTeam` INT NOT NULL AUTO_INCREMENT,
`Abv` CHAR(3) NOT NULL,
`Name` VARCHAR(45) NULL,
PRIMARY KEY (`idTeam`))
ENGINE = InnoDB
DEFAULT CHARACTER SET = utf8;
-- -----------------------------------------------------
-- Table `bd_sweepstake`.`stages`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `bd_sweepstake`.`stages` (
`idStage` INT NOT NULL AUTO_INCREMENT,
`Name` VARCHAR(25) NOT NULL,
`numberMatches` INT NOT NULL,
PRIMARY KEY (`idStage`))
ENGINE = InnoDB
DEFAULT CHARACTER SET = utf8;
-- -----------------------------------------------------
-- Table `bd_sweepstake`.`sweepstakes`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `bd_sweepstake`.`sweepstakes` (
`idSweepstake` INT NOT NULL AUTO_INCREMENT,
`punterName` VARCHAR(45) NOT NULL,
`idChampion` INT NOT NULL,
PRIMARY KEY (`idSweepstake`))
ENGINE = InnoDB
DEFAULT CHARACTER SET = utf8;
-- -----------------------------------------------------
-- Table `bd_sweepstake`.`scores`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `bd_sweepstake`.`scores` (
`idScore` INT NOT NULL AUTO_INCREMENT,
`idHomeTeam` INT NOT NULL,
`idAwayTeam` INT NOT NULL,
`goalsHome`INT NOT NULL,
`goalsAway` INT NOT NULL,
`idStage` INT NOT NULL,
`idSweepstake` INT NOT NULL,
PRIMARY KEY (`idScore`))
ENGINE = InnoDB
DEFAULT CHARACTER SET = utf8;
-- -----------------------------------------------------
-- INSERINDO NA TABELA `bd_sweepstake`.`teams`
-- -----------------------------------------------------
INSERT INTO `bd_sweepstake`.`teams` (`Abv`, `Name`)
VALUES ('NED', 'NETHERLANDS'),
('ARG', 'ARGENTINA'),
('CRO', 'CROATIA'),
('BRA', 'BRAZIL'),
('ENG', 'ENGLAND'),
('FRA', 'FRANCE'),
('MAR', 'MOROCCO'),
('POR', 'PORTUGAL');
-- -----------------------------------------------------
-- INSERINDO NA TABELA `bd_sweepstake`.`stages`
-- -----------------------------------------------------
INSERT INTO `bd_sweepstake`.`stages` (`Name`, `numberMatches`)
VALUES ('Quarter-Final', 4),
('Semi-final', 2),
('Final', 1);
-- -----------------------------------------------------
-- INSERINDO NA TABELA `bd_sweepstake`.`scores`
-- -----------------------------------------------------
CREATE VIEW greaterIdSweepstake AS SELECT MAX(IdSweepstake) 'maxId' FROM `bd_sweepstake`.`sweepstakes`;
SELECT * FROM greaterIdSweepstake;
-- -----------------------------------------------------
-- VIEW TO SEE THE GREATER ID IN TABLE `bd_sweepstake`.`sweepstakes`
-- -----------------------------------------------------
CREATE VIEW numberOfTeams AS SELECT Count(idTeam) 'numberTeams' FROM `bd_sweepstake`.`teams` ;
SELECT * FROM numberOfTeams;
-- -----------------------------------------------------
-- INSERINDO NA TABELA `bd_sweepstake`.`sweepstakes`
-- -----------------------------------------------------
INSERT INTO `sweepstakes` (`punterName`, `idChampion`)
VALUES ('Mateus', '6');
-- -----------------------------------------------------
-- SELECT TO GET THE TEAMS`bd_sweepstake`.`teams`
-- -----------------------------------------------------
INSERT INTO `scores` (`idScore`, `idHomeTeam`, `idAwayTeam`, `goalsHome`, `goalsAway`, `idStage`, `idSweepstake`)
VALUES (NULL, ?, ?, ?, ?, ?, ?);
-- -----------------------------------------------------
-- SELECT TO GET THE TEAMS`bd_sweepstake`.`scores`
-- -----------------------------------------------------
SELECT * FROM teams;
-- -----------------------------------------------------
-- VIEW TO SEE THE GREATER ID IN TABLE `bd_sweepstake`.`sweepstakes`
-- -----------------------------------------------------
SELECT * FROM scores;
-- -----------------------------------------------------
-- DATABASE DROPING `bd_sweepstake`
-- -----------------------------------------------------
DROP DATABASE `bd_sweepstake`;
-- -----------------------------------------------------
-- SELECT TO GET THE TEAMS`bd_sweepstake`.`sweepstakes`
-- -----------------------------------------------------
SELECT * FROM sweepstakes;
SELECT sweepstakes.idSweepstake 'idBolao', sweepstakes.punterName 'Nome do Jogador', bd_sweepstake.teams.Name 'CAMPEAO'
FROM sweepstakes natural join teams where idChampion = idTeam;
-- -----------------------------------------------------
-- SELECT TO IMPLEMENTS THE METHOD FINDALL()
-- -----------------------------------------------------
SELECT sweepstakes.idSweepstake, sweepstakes.punterName, scores.idStage,teams1.idTeam "idHomeTeam", teams1.Name "nameHome",
teams1.Abv "abvHome", scores.goalsHome, scores.goalsAway,teams2.Abv "abvAway", teams2.Name "AwayTeam", teams1.idTeam "idAwayTeam"
FROM sweepstakes,scores,teams teams1, teams teams2
WHERE sweepstakes.idSweepstake = scores.idSweepstake AND
scores.idHomeTeam = teams1.idTeam AND scores.idAwayTeam = teams2.idTeam;
select * from scores;