diff options
Diffstat (limited to 'patton-bam.sql')
-rw-r--r-- | patton-bam.sql | 35 |
1 files changed, 17 insertions, 18 deletions
diff --git a/patton-bam.sql b/patton-bam.sql index ec5113e..b3689d3 100644 --- a/patton-bam.sql +++ b/patton-bam.sql @@ -44,7 +44,7 @@ CREATE TABLE patton_scores ( h_bam FLOAT, -- punkty BAMowe dla gospodarzy v_bam FLOAT -- punkty BAMowe dla gości ); - + -- Tabela kompilująca saldo druzyn w meczu DROP TABLE IF EXISTS patton_sums; CREATE TABLE patton_sums ( @@ -120,8 +120,8 @@ INSERT INTO patton_scores JOIN scores s2 ON pb.rnd = s2.rnd AND pb.segment = s2.segment AND pb.tabl = s2.tabl AND pb.board = s2.board AND s2.room = 2; UPDATE patton_scores SET v_bam = -h_bam; --- Zmienna pomocnicza do wyliczenia punktów za saldo w zależności od liczby rozdań w rundzie. -SET @boards_per_segment = IF ((SELECT boardspersegment FROM admin) = 4, 1, 0.5); -- Dla 4 rozdań: = 1.0, dla 3 rozdań: = 0.5 +-- Zmienna pomocnicza: liczby rozdań w rundzie. +SET @boards_per_segment = (SELECT boardspersegment FROM admin); -- Wypełniamy tabelę salda. DELETE FROM patton_sums; @@ -140,31 +140,30 @@ INSERT INTO patton_sums UPDATE patton_sums SET max_saldo = IF (h_saldo > v_saldo, h_saldo, v_saldo); -- Roboczo liczymy wynik za saldo względem wyniku 0:0 --- Jeśli róznica salda > 1/3 maksymalnego, to gospodarze zdobywają: --- * 2 punkty przy 4 rozdaniach --- * 1 punkt przy 3 rozdaniach -UPDATE patton_sums SET h_points = 2 * @boards_per_segment +-- Jeśli róznica salda > 1/3 maksymalnego, to gospodarze zdobywają +-- n/2 punktów przy n rozdaniach +UPDATE patton_sums SET h_points = @boards_per_segment / 2 WHERE (max_saldo - v_saldo) / max_saldo > 1/3; -- Jeśli róznica salda > 1/10 maksymalnego, ale < 1/3, to gospodarze zdobywają: --- * 2 punkty przy 4 rozdaniach --- * 1 punkt przy 3 rozdaniach -UPDATE patton_sums SET h_points = 1 * @boards_per_segment +-- * 1 punkt przy 4 rozdaniach +-- * 1/6 * n, zaokrągloną do 0.1 przy n rozdaniach +UPDATE patton_sums SET h_points = IF(@boards_per_segment = 4, 1, ROUND(@boards_per_segment / 6, 1)) WHERE (max_saldo - v_saldo) / max_saldo BETWEEN 1/10 AND 1/3; -- Jeśli róznica salda > 1/10 maksymalnego, ale < 1/3, to goście zdobywają: --- * 2 punkty przy 4 rozdaniach --- * 1 punkt przy 3 rozdaniach -UPDATE patton_sums SET h_points = -2 * @boards_per_segment +-- n/2 punktów przy n rozdaniach +UPDATE patton_sums SET h_points = -(@boards_per_segment / 2) WHERE (max_saldo - h_saldo) / max_saldo > 1/3; -- Jeśli róznica salda > 1/10 maksymalnego, ale < 1/3, to goście zdobywają: -- * 1 punkt przy 4 rozdaniach --- * 0.5 punktu przy 3 rozdaniach -UPDATE patton_sums SET h_points = -1 * @boards_per_segment +-- * 1/6 * n, zaokrągloną do 0.1 przy n rozdaniach +UPDATE patton_sums SET h_points = -IF(@boards_per_segment = 4, 1, ROUND(@boards_per_segment / 6, 1)) WHERE (max_saldo - h_saldo) / max_saldo BETWEEN 1/10 AND 1/3; -- Druga drużyna zdobywa dopełnienie do zera. UPDATE patton_sums SET v_points = -h_points; --- Podnosimy wynik za saldo z punktu odniesienia 0:0 do właściwego remisu, zależnego od liczby rozdań (2:2 dla 4, 1:1 dla 3) -UPDATE patton_sums SET v_points = v_points + 2 * @boards_per_segment; -UPDATE patton_sums SET h_points = h_points + 2 * @boards_per_segment; +-- Podnosimy wynik za saldo z punktu odniesienia 0:0 do właściwego remisu, +-- zależnego od liczby rozdań (2:2 dla 4, 1.5:1.5 dla 3 - n/2:n/2 dla n rozdań) +UPDATE patton_sums SET v_points = v_points + @boards_per_segment / 2; +UPDATE patton_sums SET h_points = h_points + @boards_per_segment / 2; -- Kompilujemy wyrównania Pattonowe, jako sumę wyrównań z BAMów i punktów za saldo DELETE FROM patton_adjustments; |