Toon posts:

[SQL] Databasestructuur voor PB berichten moderniseren

Pagina: 1
Acties:

Vraag


  • Flipside22
  • Registratie: Juni 2017
  • Laatst online: 16-05 13:54
Beste GoT'ers,

ik heb een database structuur voor prive berichten. Hier staan een paar miljoen berichten in. Het is vrij simpel:

Table `messages` bevat een paar velden waaronder:
Afzenderid
Ontvangerid
Onderwerp
Bericht
Timestamp

Etc en wat andere velden, de id's wijzen naar een gebruikers tabel.

Op dit moment worden gewoon alle berichten onder elkaar weer gegeven die een gebruiker ontvangt. Het is dus niet 'gebundeld' per afzender. Ik wil dit upgraden (van berichtweergave naar gespreksweergave), en dus met wat aanpassingen / een query een overzicht krijgen van alle gesprekspartners.

Er zijn diverse aanpakken hiervoor, maar wat is de 'best practice'? Zonder structuur aanpassing kom ik er sowieso niet denk ik:

SQL:
1
2
3
4
5
6
SELECT 
`afz`.`username` as `afzusername`,`afz`.`id` as `afzid`,`ontv`.`username` as `ontvusername`,`ontv`.`id` as `ontvid`, MAX(`timestamp`) AS `last` 
FROM `messages`
LEFT JOIN `users` as `afz` ON `from` = `afz`.`id` 
LEFT JOIN `users` as `ontv` ON `to` = `ontv`.`id` 
WHERE `from` = :userid OR `to` = :userid GROUP BY `groupConversationIndex` ORDER BY `last` DESC


Dit is een wat versimpelde versie van de query die ik bedacht had op de huidige structuur. groupConversationIndex is het resultaat van het afzenderid + ontvangerid.
Deze query duurt te lang, ook met het gebruik van de juiste indexes.

Ik heb een andere oplossing in gedachten (dmv 2 extra tabellen), maar weet niet of dit de beste optie is. Hebben jullie suggesties?

Beste antwoord (via Flipside22 op 05-11-2018 23:12)


  • Gomez12
  • Registratie: Maart 2001
  • Laatst online: 23-07-2021
Hoe presteert je huidige query als je de or eruit haalt en vervangt door een union? En waarom gebruik je left joins naar je users tabel, is een message nog wel geldig als je geen afzender of ontvanger meer hebt? Ik zou zeggen maak daar inner joins van en ik zie niet in waarom het niet zou presteren.

Alle reacties


  • RobIII
  • Registratie: December 2001
  • Laatst online: 17:10

RobIII

Admin Devschuur®

^ Romeinse Ⅲ ja!

Flipside22 schreef op maandag 5 november 2018 @ 21:40:
Ik heb een andere oplossing in gedachten (dmv 2 extra tabellen)
[...]
Hebben jullie suggesties?
Ja, post die oplossing die je in gedacht hebt eens :?

There are only two hard problems in distributed systems: 2. Exactly-once delivery 1. Guaranteed order of messages 2. Exactly-once delivery.

Roses are red Violets are blue, Unexpected ‘{‘ on line 32.

Over mij


Acties:
  • Beste antwoord
  • +1Henk 'm!

  • Gomez12
  • Registratie: Maart 2001
  • Laatst online: 23-07-2021
Hoe presteert je huidige query als je de or eruit haalt en vervangt door een union? En waarom gebruik je left joins naar je users tabel, is een message nog wel geldig als je geen afzender of ontvanger meer hebt? Ik zou zeggen maak daar inner joins van en ik zie niet in waarom het niet zou presteren.

  • Flipside22
  • Registratie: Juni 2017
  • Laatst online: 16-05 13:54
Thanks! Met de tips van @Gomez12 kwam ik er al snel achter dat er bij het gebruik van de juiste Index e.a. mis ging. De joins vervangen, en een union van gemaakt en hij presteert nu super!


Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee