• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Wykonywanie danej czynności raz na X czasu - asp.net core web api

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
0 głosów
483 wizyt
pytanie zadane 21 kwietnia 2022 w C# przez Idezam Początkujący (410 p.)

Pytanko - prosty przykład. W mojej bazie danych użytkownicy mogą recenzować dany produkt, wpisują swoją opinię oraz przyznają ilość gwiazdek. Gwiazdki to pole typu double w bazie danych, użytkownik może ocenić produkt na 1, 1.5, 2, 2.5 gwiazdki i tak dalej aż do 5. Chciałbym, aby powiedzmy raz na 24 godziny (o godzinie 13) średnia ocena widoczna przy produkcie była aktualizowana, czyli chciałbym osiągnąć następujący efekt:

Godzina 11 - Oceny produktu: 2, 3, 4, 5 Średnia ocena = 14/4 = 3.5

Na sklepie obok produktu wyświetla się ocena: 3,5 gwiazdki.

O godzinie 12 użytkownik dodał ocenę: 1

Godzina 13:05 (po aktualizacji ocen): - Oceny produktu: 1, 2, 3, 4, 5 Średnia ocena = 15/5 = 3

Na sklepie obok produktu wyświetla się ocena: 3 gwiazdki.

No i właśnie, żeby otrzymać taki efekt to w tabeli z produktem w bazie potrzebuję mieć średnią ocen, ale te oceny w jakiś sposób o tej godzinie 13 muszą być w jakiś sposób obliczane i umieszczane w bazie, jak powinno się podejść do takiego problemu? 

komentarz 21 kwietnia 2022 przez VBService Ekspert (256,320 p.)

Sprawdź to:  Execute Code at specific time

The code that runs periodically. 

  • Windows Task scheduler
  • Windows Service
  • Create a SSIS / DTS

1 odpowiedź

0 głosów
odpowiedź 21 kwietnia 2022 przez cava96 Gaduła (3,940 p.)
Myślę, że jednym ze sposobów jest odpalenie skryptu .sql obliczającym to o danej godzinie, w bazach SQL Server można stworzyć joby, które uruchamiają się o podanej godzinie i wykonują podany kod SQL.
komentarz 21 kwietnia 2022 przez Idezam Początkujący (410 p.)
Okej, to brzmi jak jedno z potencjalnych rozwiązań tego problemu. A przychodzi Ci może do głowy jakieś rozwiązanie z kodem? Tak żeby nie uzależniać się od tego czy używamy akurat SQL Server czy np Postgres? Bo jedyne co mi przychodzi obecnie do głowy, to zamiast aktualizowania ich o konkretnej porze, aktualizować je wtedy kiedy nowa ocena zostanie dodana. Ale wygląda mi to na średni pomysł.. obliczanie średniej za każdym razem kiedy ktoś doda nową opinię, przy dużej ilości użytkowników może raczej znacząco obciążyć maszynę.
komentarz 21 kwietnia 2022 przez Oscar Nałogowiec (29,340 p.)
Dlaczego tak uważasz, przy aktualizacji co jakiś czas musisz przeglądać wszystkie pozycje, także te nie zmodyfikowane (chociażby by stwierdzić czy zostały zmodyfikowane). Jeśli baza jest bardzo dynamiczna i większość pozycji jest w czasie tego okresu zmodyfikowana, to owszem, aktualizacja okresowa może być mniej angażująca.

Jednak spójrz na to inaczej - czy obliczenie średniej to dużo pracy w porównaniu z tym, co i tak musisz robić dodająć nową opinie. Wydaje mi się, że nie.

Większość rozwiązań w ogóle nie trzyma tego typu "obliczalnych" danych w bazie - zawsze jest ryzyko naruszenia spójności danych. Można obliczać je na bieżąco w trakcie pobierania danych z bazy.
komentarz 21 kwietnia 2022 przez Idezam Początkujący (410 p.)
Okej, to brzmi sensownie. W sensie żeby obliczać coś takiego w trakcie pobierania danych i nie trzymać tego wcale w bazie bo jakby nie patrzeć też nie będzie raczej do niczego innego potrzebne. Ale zaciekawiło mnie to co napisales o ryzyku naruszenia spójności danych. O co z tym chodzi? Czego mam unikać żeby tego uniknąć? Bo w przypadku który wymieniłem to bym najzwyczajniej w świecie sobie zbierał te dane z tabeli, liczył średnią i umieszczał w innej tabeli. Co tutaj by mogło pójść nie tak względem spójności danych?

Podobne pytania

+1 głos
1 odpowiedź 352 wizyt
pytanie zadane 3 grudnia 2020 w C# przez PatrykSladek Początkujący (310 p.)
0 głosów
1 odpowiedź 748 wizyt
pytanie zadane 11 kwietnia 2021 w C# przez tomasz12345 Użytkownik (750 p.)
0 głosów
2 odpowiedzi 479 wizyt
pytanie zadane 20 grudnia 2020 w C# przez czujek22 Dyskutant (7,670 p.)

93,182 zapytań

142,196 odpowiedzi

322,002 komentarzy

62,513 pasjonatów

Advent of Code 2024

Top 15 użytkowników

  1. 2127p. - dia-Chann
  2. 2092p. - Łukasz Piwowar
  3. 2079p. - Łukasz Eckert
  4. 2037p. - Tomasz Bielak
  5. 2006p. - rucin93
  6. 2005p. - Łukasz Siedlecki
  7. 1964p. - CC PL
  8. 1835p. - Adrian Wieprzkowicz
  9. 1785p. - Michal Drewniak
  10. 1744p. - rafalszastok
  11. 1684p. - Mikbac
  12. 1624p. - Anonim 3619784
  13. 1520p. - Marcin Putra
  14. 1480p. - ssynowiec
  15. 1365p. - Dawid128
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...