Normaliseren van de database? Is dat dan niet handiger?
Dat had ik al voorgesteld...
Als debuggen van de interactie PHP - jQuery al voor problemen zorgt is database optimalisatie wellicht ook een ... te "zware opstap".
EDIT: Misschien bestaat er ook een misverstand. Die serialize aan de jQuery kant is enkel het serialiseren voor transport; aan de PHP-kant zijn $_GET en $_POST weer gewoon arrays, en elementen in je formulier die eindigen met [ rechte haken ] zijn gewoon sub-arrays van $_GET / $_POST. Dit werkt dus gewoon als voorheen, dit is niet allemaal automatisch tekst omdat je aan de jQuery kant "serialiseert".
Persoonlijk zou ik hier een koppeltabel van maken, met in elk record een gebruiker-id - mailiinglijst-id paar, maar dat terzijde.
Bedoelde je hier het normaliseren van de database mee?
Dat het item 2x voorkomt is inderdaad een foutje, maar dat krijg ik er later wel uit.
Ik heb nu de kolom een LONGTEXT gegeven. Maar nog steeds is er niks weggeschreven in de database. Zou het kunnen dat die geen array's kan wegschrijven? Ik zal nu eens proberen met die implode.
[size=xsmall]Toevoeging op 04/02/2015 13:18:43:[/size]
Wat gaat er met de id gebeuren als ik de implode gebruik? Ik serialiseer de hele form ineens vandaar dat ook de ID in de array zit. Die moet er natuurlijk apart uit getrokken worden anders kan hij dit niet opslaan bij een bepaald id in de tabel. Ik denk dat daar de fout zit. Hoe kan ik dit oplossen?
implode (',', '$_POST['mclijst_id']);
[size=xsmall]Toevoeging op 04/02/2015 13:26:14:[/size]
Ik heb even wat testen gedaan met de debugger:
Ik zet dit in mijn test7.php:
Lees mijn bijgewerkte vorige reactie, misschien heb je de werking van de jQuery functie serialize() verkeerd begrepen.
En ja, als je je geserialiseerde tekst in je database weer uit wilt lezen en het array van ids wilt doorlopen zul je de omgekeerde bewerking (explode()) moeten uitvoeren. Vandaar mijn opmerking over een mogelijk andere aanpak.
Wel zou je die kolom in een IN statement in MySQL kunnen gebruiken, wellicht (mits deze niet leeg is). Dit lijkt mij echter niet optimaal.