forked from cryptoluka/LuKaDice
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdatabase.sql
65 lines (52 loc) · 1.73 KB
/
database.sql
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
create database dice;
use database dice;
create table player (
idplayer VARCHAR(36) NOT NULL PRIMARY KEY,
paymentid VARCHAR(64) NOT NULL,
balance NUMERIC(15,8) NOT NULL,
nickname VARCHAR(100) NOT NULL,
username VARCHAR(70) NOT NULL,
password VARCHAR(70) NOT NULL,
email VARCHAR(200) NULL,
creationtime datetime NOT NULL DEFAULT NOW(),
lastupdate datetime NULL
);
create table rollhistory(
idgame VARCHAR(36) NOT NULL PRIMARY KEY,
idplayer VARCHAR(36) NOT NULL,
nickname VARCHAR(100) NOT NULL,
bet NUMERIC(15,8) NOT NULL,
target NUMERIC(5,2) NOT NULL,
number NUMERIC(5) NOT NULL,
profit NUMERIC(15,8) NOT NULL,
result BOOL,
creationtime datetime NOT NULL DEFAULT NOW(),
lastupdate datetime NULL
);
ALTER TABLE rollhistory
ADD FOREIGN KEY (idplayer) REFERENCES player(idplayer);
----------------
-- QUERYS
----------------
-- GET INFO FROM USERS
SELECT p.nickname, p.email, SUM(r.bet), p.balance, (50 - p.balance) AS 'Profit', p.password
FROM rollhistory r
JOIN player p ON p.idplayer = r.idplayer
GROUP BY p.nickname, p.email, p.password, p.balance
ORDER BY sum(r.bet) DESC;
-- GET JACKPOT TOTAL ^8 (100%)
SELECT ROUND(SUM(ab.Profit), 8) AS 'JACKPOT' FROM player pl
JOIN (
SELECT r.idplayer AS 'nick', (50 - p.balance) AS 'Profit'
FROM rollhistory r
JOIN player p ON p.idplayer = r.idplayer
GROUP BY p.nickname, r.idplayer, p.balance, (50 - p.balance)
) ab ON pl.idplayer = ab.nick;
-- GET JACKPOT PAYABLE ^8 (66%) ^8
SELECT ROUND(((SUM(ab.Profit) / 3) * 2),8) AS 'JACKPOT' FROM player pl
JOIN (
SELECT r.idplayer AS 'nick', (50 - p.balance) AS 'Profit'
FROM rollhistory r
JOIN player p ON p.idplayer = r.idplayer
GROUP BY p.nickname, r.idplayer, p.balance, (50 - p.balance)
) ab ON pl.idplayer = ab.nick;