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
?
Onbekende gebruiker
18-07-2009 19:46
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):
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.
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?
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.
?
Onbekende gebruiker
18-07-2009 21:00
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.