hi,
Ein Ansatz habe ich bei Joomla gesehen, hier werden alle Daten in EINEM Feld gespeichert mit einem , getrennt, aber ich gehe davon aus, dass dieses noch um einiges schwerer ist zu speichern, bearbeiten und löschen?
Billiglösung ;)
Wenn Du direkt adressieren möchtest (was Insert, Delete, Update erleichtert), brauchst Du _zwei_ Felder, eins für den Array-Index und eins für den Wert. Ich würde mich da schon eher in Richtung ORM (wurde hier auch genannt) bewegen, die Datenhaltung ist da soweit abstahiert, dass Du im Code mit dem User als Objekt hantierst, Attribute sind Name, Vorname usw., die Sprache ist dann ein Array und SQL-Statements sind komplett raus aus Deinem Code.
$User->lang(3) = 'de';
wäre z.B. ein Methoden-Aufruf für eine User-Instanz und einer Left-Value-Methode und
$User->write();
der Aufruf einer Methode, welche die geänderten Daten eines Benutzer-Objekts wieder persistent macht.
Es ist auch nicht weiter schwierig, einen ORM selbst zu entwickeln, wir kochen alle nur mit Wasser.
Zu Deinem Code weiter unten, Stichwort Session: Auch wenn $_SESSION
eine globale Variable ist, ich würde da einen Wrapper draufsetzen, sprich, eine Funktion wo direkt die User-ID eines in der Session angemeldeten Benutzers liefert. Der Wrapper könnte eine class Session{}
sein, nicht der OOP willens, sondern einfach nur deswegen, dass der Code übersichtlicher wird und die in der Session abgelegten Datenstrukturen klar definiert sind.
Horst