Avatar billede hrole Mester
17. november 2018 - 14:22 Der er 4 kommentarer

Vagtskema

Hej,
Jeg er gået i stå med et vagtskema. Databasestrukturen er:
Id - dato - dag - bruger_1 - bruger _2 - bruger_3 - bruger_4 - bruger_5

Først har de enkelte brugere indsat ønsker fri (F), kursus (K), andet (A).

Herefter skal dagvagt (D) og aftenvagt (A) og kontor (O) fordeles fuldstændigt ligeligt. Pr. dag: Én bruger har dagvagt, én bruger har aftenvagt og resten har kontor. Desuden skal alle have præcis lige mange aftenvagter fredage og præcis lige mange dagvagter mandage. Men det er fx ok at én bruger har to aftenvagter tirsdag-torsdag
Avatar billede olsensweb.dk Ekspert
17. november 2018 - 14:39 #1
start med at normalisere din Databasestruktur

noget ala:

tbl_user:
id, navn


tbl_skema
id, usr_id, dato

dagen kan du udregne ud fra din dato
Avatar billede hrole Mester
17. november 2018 - 15:16 #2
Jeg kan ikke umiddelbart se fordelen, måske du kan uddybe? JEg er med på at jeg kan regne dag udfra dato.
Avatar billede olsensweb.dk Ekspert
17. november 2018 - 18:57 #3
>Jeg kan ikke umiddelbart se fordelen,
man gør det for ikke at have spildplads i databasen
man gør det for at undgå redundant data

https://www.google.dk/search?q=database+normalisering
https://mariadb.com/kb/en/library/database-normalization/
https://balslev.io/programmering/database/normalisering-af-databaser/
http://www.udvikleren.dk/artikler/146/normalformer-baseret-paa-primaernoegler/


et hurtigt forslag til database design
CREATE TABLE `tbl_skema` (
  `id` int(11) NOT NULL,
  `user_id` int(11) NOT NULL,
  `vagt_type_id` int(11) NOT NULL,
  `dato` date NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;


INSERT INTO `tbl_skema` (`id`, `user_id`, `vagt_type_id`, `dato`) VALUES
(1, 3, 2, '2018-11-19'),
(2, 4, 1, '2018-11-19'),
(3, 1, 1, '2018-11-19'),
(4, 1, 3, '2018-11-18');

CREATE TABLE `tbl_users` (
  `id` int(11) NOT NULL,
  `firstname` varchar(255) COLLATE utf8_danish_ci NOT NULL,
  `lastname` varchar(255) COLLATE utf8_danish_ci NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_danish_ci;


INSERT INTO `tbl_users` (`id`, `firstname`, `lastname`) VALUES
(1, 'rip', 'andemad'),
(3, 'rap', 'and'),
(4, 'rup', 'and'),
(5, 'mickey', 'mouse'),
(7, 'bimmer', 'vildmand'),
(8, 'jule', 'mand');

CREATE TABLE `tbl_vagt_typer` (
  `id` int(11) NOT NULL,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_danish_ci NOT NULL,
  `tid_start` time NOT NULL,
  `tid_slut` time NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;


INSERT INTO `tbl_vagt_typer` (`id`, `name`, `tid_start`, `tid_slut`) VALUES
(1, 'dagvagt', '07:00:00', '15:00:00'),
(2, 'aftenvagt', '15:00:00', '23:00:00'),
(3, 'kontor', '07:00:00', '15:00:00');


ALTER TABLE `tbl_skema`
  ADD PRIMARY KEY (`id`);


ALTER TABLE `tbl_users`
  ADD PRIMARY KEY (`id`),
  ADD KEY `idx_lastname` (`lastname`);


ALTER TABLE `tbl_vagt_typer`
  ADD PRIMARY KEY (`id`);


ALTER TABLE `tbl_skema`
  MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=5;


ALTER TABLE `tbl_users`
  MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=9;


ALTER TABLE `tbl_vagt_typer`
  MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=4;



udtræk
SELECT * FROM `tbl_skema` JOIN tbl_users on tbl_skema.user_id = tbl_users.id JOIN tbl_vagt_typer on tbl_skema.vagt_type_id = tbl_vagt_typer.id


SELECT * FROM `tbl_skema` JOIN tbl_users on tbl_skema.user_id = tbl_users.id JOIN tbl_vagt_typer on tbl_skema.vagt_type_id = tbl_vagt_typer.id WHERE tbl_skema.dato ='2018-11-19'
Avatar billede hrole Mester
24. november 2018 - 10:44 #4
Tak for svar. Jeg kan se pointen.

Men hvordan får jeg fordelt vagterne fuldstændigt ligeligt, når brugerne har indsat ønsker?

Pr. dag: Én bruger har dagvagt, én bruger har aftenvagt og resten har kontor. Desuden skal alle have præcis lige mange aftenvagter fredage og præcis lige mange dagvagter mandage. Men det er fx ok at én bruger har to aftenvagter tirsdag-torsdag
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester



IT-JOB