Ik ben bezig met een script waarvoor is niet belangrijk.

Maar ik moet 5 waardes in een database stoppen.
En het is nogal onhandig als ik 5 rijen moet aanmaken.
daarom wil ik het in 1 stoppen.

Nu heb ik wel eens van de functie explode gehoort maar weet niet of het hier de goede functie voor is.

Stel ik heb een veld.

0,34,23,65,45

Hoe kan ik bijv hier alle 5 de waardes er apart uithalen.
en dan zo echo'en
Veld1:0
veld2:34
veld3:23
enz
1). Gooi NOOIT meerdere waardes in een veld in de tabel! Een veld mag (officieel) maar een waarde bevatten. Als je meerdere waardes in een veld moet doen, is je database/tabel niet goed genoeg genormaliseerd en zul je je dat dus eerst moeten doen.
2). Explode zul je dan zo moeten gebruiken (zie ook [php]explode[/php]() in de PHP.net documentatie):
<?php
$veld = '0,34,23,65,45';
$aWaardes = explode(',', $veld);
Ah oke dan toch maar wat informatie.

Ik ben bezig met een browsergame.

Gebouwen hebben 20 lvls.

Tabel.
CREATE TABLE IF NOT EXISTS `kosten` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`naam` varchar(32) NOT NULL,
`lvl1` varchar(255) NOT NULL,
`lvl2` varchar(255) NOT NULL,
`lvl3` varchar(255) NOT NULL,
`lvl4` varchar(255) NOT NULL,
enz enz

Anders moet ik meerdere tabel velden gaan aanmaken
`lvl1grondstof1` varchar(255) NOT NULL,
`lvl1grondstof2` varchar(255) NOT NULL,
`lvl1grondstof3` varchar(255) NOT NULL,
`lvl1grondstof4` varchar(255) NOT NULL,
`lvl1grondstof5` varchar(255) NOT NULL,
`lvl2grondstof1` enz enz

En dat leek mij dus niet handig.
Aangezien ik dan nog 80 velden moest aanmaken.

Dus u raad mij dit dus af?
Gebruik int in plaats van varchar voor numerieke waarden. Ik weet niet hoe hoog een lvlgrondstof kan gaan maar ik neem aan tot honderd. int(3) is dan voldoende.

Ik snap je achterliggende gedachte niet. wat is het nut van deze informatie in je database?
Ik ga het denk ik toch met explode doen.
Heb net de functie doorgenomen.
En het werkt eigenlijk perfect.

Varchar gebruikte ik net omdat in de orginele tabel 44,44,44,44,44 kwam te staan. in INT kan dat niet.

En inderdaad. als ik het zo zou doen. is dit beter. `lvl1grondstof1` int(11) NOT NULL,

Het nut van deze informatie als bijv dat je weet waneer Hoe duur bijv een upgrade naar lvl 2.

Nee, doe het niet met explode. Fix je datamodel. Hier ga je problemen mee krijgen.
stop die informatie dan in een gewone array. Het klinkt alsof hij voor iedereen hetzelfde is. het heeft dus volgens mij geen nut om deze informatie in je database te zetten.
Je kan het ook met PHP allemaal uitrekenen. Al die onzin met komma's en dergelijke is helemaal niet nodig.
Dus je gaat serieus voor elk level de grondstofkosten van een gebouw/unit/what ever in de tabel zetten??!?!

Doe het dan efficient:
idBuilding | grondstof 1 | grondstof 2 | grondstof 3 | grondstof 4

Dit is gewoon voor het basis-level. Vervolgens met een formule de overige levels DYNAMISCH berekenen, dus niet in de database opslaan. Je houdt alleen bij welk level het gebouw/unit/what ever op dit moment is en met de formule reken je automatisch de kosten uit. Als je slim bent gebruik je een exponentiele formule.
Agree @ hierboven: fix je datamodel, geen onnodige dingen opslaan, gewoon basis in php, en slechts paar dingetjes in database, en daarmee gaan rekenen.
Klopt wat jullie zeggen is inderdaad beter.
Zo blijft ook de database overzichtelijk.

Ik weet zo alleen niet hoe je het moet berekenen.
Iemand sugesties?

Reageren