This repository has been archived by the owner on Dec 21, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqueries.sql
87 lines (81 loc) · 3.88 KB
/
queries.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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
--Put queries here
--Q1
SELECT ROUND(AVG(CRICHARDSON5.beat_heartrate.HRVALUE)) AS AVG_HR, MIN(CRICHARDSON5.beat_heartrate.HRVALUE) as MIN_HR, MAX(CRICHARDSON5.beat_heartrate.HRVALUE) AS MAX_HR
FROM CRICHARDSON5.beat_event JOIN CRICHARDSON5.beat_heartrate
ON (
crichardson5.beat_event.USERID = crichardson5.beat_heartrate.USERID AND
crichardson5.beat_heartrate.TIME_STAMP BETWEEN crichardson5.beat_event.TSTART AND crichardson5.beat_event.TEND
)
WHERE crichardson5.beat_event.USERID = :uuid AND
crichardson5.beat_event.TSTART BETWEEN :starttime AND :endtime AND
crichardson5.beat_event.CAT = :category
--Q2
SELECT ce.tstart STIME, round(avg(hr.hrvalue)) AVGHR, max(hr.hrvalue) MAXHR ,min(hr.hrvalue) MINHR
FROM (
SELECT ROW_NUMBER() OVER (ORDER BY tstart) i1, tstart, cat, userid, tend
FROM crichardson5.beat_event
WHERE cat = :catone or cat = :cattwo ) ce
INNER JOIN
(SELECT ROW_NUMBER() OVER (ORDER BY tstart) i2, tstart, cat, userid
FROM crichardson5.beat_event
WHERE cat=:catone or cat = :cattwo ) pe
ON ce.i1 = pe.i2 + 1,
crichardson5.beat_heartrate hr
WHERE
ce.userid = pe.userid AND
ce.userid = hr.userid AND
ce.userid = :uuid AND
pe.cat = :catone AND
ce.cat = :cattwo AND
ce.tstart BETWEEN :daystart AND :dayend AND
hr.time_stamp BETWEEN ce.tstart AND ce.tend
GROUP BY ce.tstart
ORDER BY ce.tstart
--Q3
SELECT TO_TIMESTAMP(TSTART, 'YYYY-MM-DD HH24:MI:SS') AS start_time, TO_TIMESTAMP(TEND, 'YYYY-MM-DD HH24:MI:SS') AS end_time, MAX(HRVALUE), TO_TIMESTAMP(MAX(TEND), 'YYYY-MM-DD HH24:MI:SS') - TO_TIMESTAMP(MIN(TSTART), 'YYYY-MM-DD HH24:MI:SS') AS Duration
FROM crichardson5.beat_heartrate , crichardson5.beat_event
WHERE crichardson5.beat_event.USERID = crichardson5.beat_heartrate.USERID AND
crichardson5.beat_event.USERID = :uuid AND
crichardson5.beat_event.CAT = 'fitness' AND
crichardson5.beat_event.TSTART BETWEEN :timestart AND :timeend AND
crichardson5.beat_heartrate.TIME_STAMP BETWEEN crichardson5.beat_event.TSTART AND crichardson5.beat_event.TEND
GROUP BY crichardson5.beat_event.tstart, crichardson5.beat_event.tend
ORDER BY crichardson5.beat_event.tstart ASC
--Q4
SELECT TEND, ROUND(AVG(HRVALUE)) AS average, MIN(HRVALUE) AS min, MAX(HRVALUE) AS max, TO_TIMESTAMP(MAX(TEND), 'YYYY-MM-DD HH24:MI:SS') - TO_TIMESTAMP(MIN(TSTART), 'YYYY-MM-DD HH24:MI:SS') AS Duration
FROM (
SELECT *
FROM CRICHARDSON5.beat_event E, CRICHARDSON5.beat_heartrate H
WHERE E.TEND BETWEEN :timestart AND :timeend AND
E.CAT = 'rest' AND
E.USERID = H.USERID AND
E.USERID = :uuid AND
H.time_stamp BETWEEN E.TSTART AND E.TEND
)
GROUP BY TEND
--Q5
SELECT
ROUND(100 - (((avghr_d-avghr_r)/avghr_r)*100)) as recovery_score,
DAY
FROM
-- resting HR avg for all days in the given range
(SELECT
ROUND(AVG(hrvalue)) AS avghr_r,
crichardson5.beat_heartrate.userid AS id
FROM crichardson5.beat_heartrate, crichardson5.beat_event
WHERE
crichardson5.beat_heartrate.userid = :uuid AND
cat='rest' AND
crichardson5.beat_heartrate.time_stamp BETWEEN :timestart AND :timeend
GROUP BY crichardson5.beat_heartrate.userid
),
-- avg HR values per day in the given range
( SELECT ROUND(AVG(hrvalue)) as avghr_d,USERID, DAY
FROM( SELECT crichardson5.beat_heartrate.USERID USERID,crichardson5.beat_heartrate.HRVALUE HRVALUE,SUBSTR(TSTART, 1, 10) AS DAY
FROM crichardson5.beat_heartrate, crichardson5.beat_event
WHERE crichardson5.beat_event.tstart BETWEEN :timestart AND :timeend AND
crichardson5.beat_heartrate.time_stamp BETWEEN crichardson5.beat_event.TSTART AND crichardson5.beat_event.TEND
AND cat='rest'
AND crichardson5.beat_heartrate.userid = :uuid) new_dates
GROUP BY USERID, DAY ORDER BY DAY ASC)
WHERE id = %s