Ja of wel, afaik kan PHP niet maar geheugen assignen dan de hoeveelheid RAM die je hebt. Tenminste daar liep ik tegen aan toen ik aan het kutten was met een bitmap in een array stoppen (NIET DOEN!!!)quote:
Ik heb de woorden tabel geindexeerd en de verwijzing ernaar in de andere tabel ook. Het is gewoon het standaard type, ik doe dat op de volgende manier:quote:Op maandag 25 februari 2008 22:47 schreef Farenji het volgende:
[..]
Wat voor indexes gebruik je precies, en van wat voor type zijn die? En hoe match je op de woorden, doe je dat letterlijk (where field = "blaat"), met een LIKE of met een fulltext search?
1 |
Je kunt een script toch na xxx records 3 seconden laten wachten het script middels header weer aanroepen en verder gaan waar je gebleven bent? zo draai ik cronjobs voor databases met meer dan 1 milj records!quote:Op maandag 25 februari 2008 22:34 schreef ErikN het volgende:
+ ik weet dat het kan. Heb er ook al wel wat over gelezen. Alleen begrijp er niet veel van nog...
Je hebt natuurlijk altijd geheugenbeperkingen maar dat ligt ook aan de implementatie. Met 1 image die je wil verwerken heb je weinig keus maar als je bijv een db import draait dan moet je natuurlijk niet die hele import eerst in je geheugen lezen en daarna pas wegschrijven. Als je dit netjes per record itereert dan kost het nauwelijks geheugen. Ik maak zelf regelmatig scripts voor tabellen met miljoenen rows, geen enkel probleem.quote:Op maandag 25 februari 2008 23:02 schreef WyriHaximus het volgende:
[..]
Ja of wel, afaik kan PHP niet maar geheugen assignen dan de hoeveelheid RAM die je hebt. Tenminste daar liep ik tegen aan toen ik aan het kutten was met een bitmap in een array stoppen (NIET DOEN!!!).
Je moet natuurlijk wel je script fatsoenlijk bouwen idd. Maar me punt was meer dat het aan ze bak kon liggen (niet waarschijnlijk). Aan de andere kant heb ik hier een oude P3 met 196MB RAM staan als thuis servertje die scripts draait waar rustig 90.000 reccords door heen worden geschoten dus het moet een aardige brakke dev bak zijn danquote:Op dinsdag 26 februari 2008 09:53 schreef Farenji het volgende:
[..]
Je hebt natuurlijk altijd geheugenbeperkingen maar dat ligt ook aan de implementatie. Met 1 image die je wil verwerken heb je weinig keus maar als je bijv een db import draait dan moet je natuurlijk niet die hele import eerst in je geheugen lezen en daarna pas wegschrijven. Als je dit netjes per record itereert dan kost het nauwelijks geheugen. Ik maak zelf regelmatig scripts voor tabellen met miljoenen rows, geen enkel probleem.
In stappen.quote:Op dinsdag 26 februari 2008 09:08 schreef Xcalibur het volgende:
Ik denk dat een FULLTEXT search wel sneller is dan een WHERE / LIKE?
Chandler: codevoorbeeldje?
Dit klinkt als heel veel losse stappen. Wat ik zou doen is mysql het zware werk laten doen: een dergelijke zoekmethode kun je volgens mij prima vangen in 1 of 2 queries die je opbouwt aan de hand van de argumenten (zoekwoorden, sorteervolgorde, AND/OR). Mysql is oha veel efficienter in sorteren van resultaten dan je zelf ooit kan doen in php. Er zijn ook vele verschillende sorteeralgoritmes, de een efficienter dan de ander, en de een is ook geschikter voor een bepaalde taak dan de ander, je moet maar net de juiste kiezen. Mysql zal meestal de best (beschikbare) methode gebruiken. Het zou goed kunnen dat daar je bottleneck ligt.quote:Op maandag 25 februari 2008 23:55 schreef The_Terminator het volgende:
[..]
Ik heb de woorden tabel geindexeerd en de verwijzing ernaar in de andere tabel ook. Het is gewoon het standaard type, ik doe dat op de volgende manier:
[ code verwijderd ]
Verder gebruik ik idd gewoon where, en de search kan naar meerdere woorde zoeken, dat kan zowel met een OR of AND operator.
Het script zoekt eerst naar het woord in de database en voert dat voor elk woord uit en daar komen dan topicnummers voor terug. Vervolgens worden de gevonden topics in een array gezet en krijgen ze een bepaalde score. Als een woord vaker voorkomt in een bepaald topic dan wordt die score verhoogd. Vervolgens sorteer ik die array en komen de meest relevante topics bovenaan te staan, als datum als sorteervolgorde is gekozen dan worden gewoon de topics met het grootste of kleinste topicnr. bovenaan gezet. Vervolgens kijkt het script of alle opgegeven woorden (als AND is gebruikt) voorkomen in een bepaald topic en worden de resultaten die doorkomen op de pagina geprint. Bij OR worden gewoon alle resultaten geprint.
Waarom wil je er een pauze in ? Je pakt toch max 250 tegelijk, waarom de pauze?quote:Op dinsdag 26 februari 2008 18:22 schreef Chandler het volgende:
om je script te pauzeren, echter kun je dan daarvoor beter als je een mysql connectie hebt gemaakt deze sluiten met mysql_close of je doet een refresh middels javascript!
Je gunt die server helemaal niets, aangezien iedere actie pas wordt gestart als de vorige is afgerond. Het kan een server echt niets schelen of 'ie continu door moet of 3 seconden rust krijgt.quote:Op dinsdag 26 februari 2008 20:37 schreef Chandler het volgende:
waarom niet saban, je gunt de server zo even wat meer ademruimte, zekers handig als je op een shared server zit
Of je je script nou nu aanroept of over 3 seconde, wat maakt dat uit?quote:Op dinsdag 26 februari 2008 20:37 schreef Chandler het volgende:
waarom niet saban, je gunt de server zo even wat meer ademruimte, zekers handig als je op een shared server zit
SELECT * FROM `scores` WHERE `naam`='$speler' ORDER BY `tijd` ASCquote:Op woensdag 27 februari 2008 13:36 schreef CraZaay het volgende:
ORDER BY timestamp DESC, LIMIT 30
Geeft de 30 rows met de hoogste timestamps, van hoog naar laag.
Dat ligt aan een maximum aantal mails per keer dat in de mailserverconfig ingesteld. Dat heeft niks met belasting te maken. Een server gaat niet kapot van belasting, volgens mij dicht je die dingen iets te veel menselijke eigenschappen toequote:Op woensdag 27 februari 2008 16:18 schreef Chandler het volgende:
Die sleep mag je idd vergeten, maar het script stoppen en dan na bv 3-5 seconden weer aanroepen lijkt mij beter voor de server, zelfde als 10000 emails in 1x versturen, dat vind een server ook niet leukmaar als je 250 per batch verstuurd is er niets aan de hand
lama, ik heb het al gefikst:quote:Op woensdag 27 februari 2008 16:42 schreef PiRANiA het volgende:
Voor de duidelijkheid, dit is er wat er in mijn tabel staat (fictief):
1
2
3
4
5
6
7
8
9
het vetgedrukte is wat ik wil hebben...
quote:$speler=mysql_real_escape_string($_GET['speler']);
$res=mysql_fetch_array(mysql_query("SELECT COUNT(*) AS limiet FROM `scores` WHERE `naam`='$speler'"));
$wer=$res['limiet'];
if($wer>$maxopvragingen){
$wer=$wer-$maxopvragingen;
}ELSE{
$wer='0';
}
$q="SELECT * FROM `scores` WHERE `naam`='$speler' ORDER BY `tijd` ASC LIMIT $wer,$maxopvragingen";
Nee, de eerste 30. Je wilt DESC ipv ASC gebruiken om van hoog naar laag te sorteren.quote:Op woensdag 27 februari 2008 16:38 schreef PiRANiA het volgende:
[..]
SELECT * FROM `scores` WHERE `naam`='$speler' ORDER BY `tijd` ASC
limit 30 er achter en hij neemt de laatste 30?
maar lukt dat ook met het result direct van de query?quote:Op woensdag 27 februari 2008 18:37 schreef CraZaay het volgende:
Precies, bovenstaande code geeft al een array terug. Even array_reverse() erover en klaar.
Maar een subquery hiervoor is vast niet efficienter als het over 30 records gaat, maar dat zou je kunnen benchmarkenquote:Op woensdag 27 februari 2008 19:04 schreef Xcalibur het volgende:
ja, maar het in je query doen is mooier
Nee, want dat is een resource waar je zo niets mee kan (het directe resultaat van mysql_query()). PHP moet er nog wel een array van maken.quote:Op woensdag 27 februari 2008 20:02 schreef PiRANiA het volgende:
maar lukt dat ook met het result direct van de query?
ja idd, maar dat wordt lastig denk ik. Of je moet er eenquote:Op woensdag 27 februari 2008 20:08 schreef CraZaay het volgende:
[..]
Nee, want dat is een resource waar je zo niets mee kan (het directe resultaat van mysql_query()). PHP moet er nog wel een array van maken.
in gooien maar dat lijkt me niet echt efficientquote:while($row=mysql_fetch_array($result)){
array_push($array,$row);
}
array_revert($array);
leest mijn 1e postquote:Op woensdag 27 februari 2008 17:29 schreef CraZaay het volgende:
[..]
Nee, de eerste 30. Je wilt DESC ipv ASC gebruiken om van hoog naar laag te sorteren.
Je wilt de tijd dus niet op chronologische volgorde van laag naar hoog, en dan de 30 records met de hoogste waarde? Dat is namelijk wat mijn code doetquote:Op woensdag 27 februari 2008 20:21 schreef PiRANiA het volgende:
[..]
leest mijn 1e postik wil de volgorde behouden...
k...maar ik had het inmiddels al gefikst hoorquote:Op woensdag 27 februari 2008 20:23 schreef CraZaay het volgende:
[..]
Je wilt de tijd dus niet op chronologische volgorde van laag naar hoog, en dan de 30 records met de hoogste waarde? Dat is namelijk wat mijn code doetMits je er een array van maakt uiteraard, maar dat moet je gewoon oplossen in je database layer of voor een ActiveRecord-achtige implementatie kiezen. Je wilt sowieso niet overal die hard queries typen, maar een database wrapper maken.
Zou een array_revert op een array met 30 elementen langzamer zijn dan een hele extra query?quote:Op woensdag 27 februari 2008 20:20 schreef PiRANiA het volgende:
[..]
ja idd, maar dat wordt lastig denk ik. Of je moet er een
[..]
in gooien maar dat lijkt me niet echt efficient
het gaat vooral om dat hele fetchen er voor...quote:Op woensdag 27 februari 2008 20:39 schreef Igen het volgende:
[..]
Zou een array_revert op een array met 30 elementen langzamer zijn dan een hele extra query?
Het artikel is 5 jaar oud he, voor de duidelijkheid. Template engines zijn uit, MVC is in.quote:Op woensdag 27 februari 2008 21:29 schreef Tarabass het volgende:
Ik was me een beetje aan het verdiepen in template engines. Sommige groot, sommige klein, maar vond ze over het algemeen omslachtig. Bovendien moet alles geparsed worden. Tijdens mijn zoektocht kwam ik dit artikel tegen. Wat vinden jullie van zijn stelling en class? Dus een template-class of een template-engine?
Is dat niet te combineren dan, templates en MVC?quote:Op woensdag 27 februari 2008 22:16 schreef CraZaay het volgende:
[..]
Het artikel is 5 jaar oud he, voor de duidelijkheid. Template engines zijn uit, MVC is in.
De "V" in MVC staat voor view, templates dusquote:Op woensdag 27 februari 2008 22:25 schreef Light het volgende:
[..]
Is dat niet te combineren dan, templates en MVC?
Het lijkt me heeeeeel sterkquote:Op donderdag 28 februari 2008 01:05 schreef Geqxon het volgende:
Call me crazy, maar kan het zijn dat in de recente versies van MySQL je niet meer rekensommen kan toepassen in een UPDATE statement? Dus zo van " `Sort` = `Sort` + 1 " ?
Krijg je een mysql foutmelding dan?quote:Op donderdag 28 februari 2008 01:05 schreef Geqxon het volgende:
Call me crazy, maar kan het zijn dat in de recente versies van MySQL je niet meer rekensommen kan toepassen in een UPDATE statement? Dus zo van " `Sort` = `Sort` + 1 " ?
Dat het artikel zo oud was wist ik. Dat MVC in is wist ik niet en heb daar ook nog nooit van gehoord. Ik ga me inlezen en kom wellicht met vragen terugquote:Op woensdag 27 februari 2008 22:16 schreef CraZaay het volgende:
[..]
Het artikel is 5 jaar oud he, voor de duidelijkheid. Template engines zijn uit, MVC is in.
Oké, maar zijn er goeie voorbeelden of tutorials te downloaden waaruit ik het kan leren en zelf kan doen? Ik moet toch ergens beginnenquote:Op donderdag 28 februari 2008 11:10 schreef Geqxon het volgende:
Wat een goede MVC is? MVC is een methode, een manier om iets te ontwikkelen. Niet iets dat je als een framework of engine zomaar even download.
Och, ik gebruik backticks. Gaat prima zo.quote:Op donderdag 28 februari 2008 11:14 schreef Xcalibur het volgende:
is Sort geen gereserveerd woord toevallig? Ik gebruik altijd sortorder voor zo'n kolom....
Nee, dat niet. Ik heb de cakephp nu gedownload en moet nu naar mn werk, maar zal vanavond eens die "learn-sectie" van hun site doornemen. Bedankt voor de tips tot dusverquote:Op donderdag 28 februari 2008 11:17 schreef Dzy het volgende:
Heb je wel eens met zo'n framework gewerkt tarabass? Als je even in cakephp duikt is het snel duidelijk hoe zo'n MVC werkt, daar wordt je geforceerd zo te werken. Very OOP
Niks mis mee toch? Ga zelf eem template engine bouwen voor het MVC framework wat ik gebruik (CakePHP)quote:Op donderdag 28 februari 2008 11:24 schreef Geqxon het volgende:
Zelf beken ik met schaamte dat ik nog met een template engine werk.
Mijn huidige systeem werkt eigenlijk als volgt:quote:Op donderdag 28 februari 2008 11:44 schreef WyriHaximus het volgende:
[..]
Niks mis mee toch? Ga zelf eem template engine bouwen voor het MVC framework wat ik gebruik (CakePHP).
En waar gebruik je de views dan voor? Ik ben niet bekend met Cake (wel met Code Igniter), maar views zijn toch al templates?quote:Op donderdag 28 februari 2008 11:44 schreef WyriHaximus het volgende:
[..]
Niks mis mee toch? Ga zelf eem template engine bouwen voor het MVC framework wat ik gebruik (CakePHP).
MVC is een manier om je applicatie te structureren, het is geen framework, het is geen software. Het is een aantal richtlijnen voor de architectuur: je scheidt je applicatie op in 3 logische basisblokken: model (datamodel en objectmodel), view (de interface voor de gebruiker) en de controller (die view en model aan elkaar koppelt). Hoe je dat doet is aan jezelf, je kan het van a tot z zelf opbouwen, je kan er verschillende losse modules voor gebruiken of je kan een compleet framework als Cake of Catalyst of wat dan ook voor gebruiken.quote:Op donderdag 28 februari 2008 12:14 schreef Chandler het volgende:
Ik gebruik geen MCV's juist omdat ik wil weten wat mijn code doet en het liefst zelf alles van a-z maak (met soms een beetje hulp van FOK)
Natuurlijk wordt een view ook door een template engine gehaald, er moet immers variabele data in. Maar das imo iets anders dan bijv. een Smarty. En natuurlijk is MVC zo oud als de weg naar Rome, maar wordt het daar een slechter concept door?quote:Op donderdag 28 februari 2008 12:39 schreef Farenji het volgende:
En in webapplicaties bestaat die view meestal gewoon uit een template engine. Het is onzin om te beweren dat template engines "uit" zouden zijn. En MVC is zelf trouwens ook al zo oud als de weg naar rome.
Idd. Alleen mis ik wat dingen, mogelijkheden en opties vandaar dat ik er een eigen systeem voor ga bouwen om dat af te handelenquote:Op donderdag 28 februari 2008 12:09 schreef CraZaay het volgende:
[..]
En waar gebruik je de views dan voor? Ik ben niet bekend met Cake (wel met Code Igniter), maar views zijn toch al templates?
het is MVC, Model View Controller, en het is wat anders dan een framework waar mee jij het verward. Het is een design pattern.quote:Op donderdag 28 februari 2008 12:14 schreef Chandler het volgende:
Ik gebruik geen MCV's juist omdat ik wil weten wat mijn code doet en het liefst zelf alles van a-z maak (met soms een beetje hulp van FOK)
Ik heb niet gezegd dat MVC een slecht concept is, integendeel, ik ben een grote fan van MVC. Maar wat is Smarty anders dan een template engine?quote:Op donderdag 28 februari 2008 13:06 schreef CraZaay het volgende:
[..]
Natuurlijk wordt een view ook door een template engine gehaald, er moet immers variabele data in. Maar das imo iets anders dan bijv. een Smarty. En natuurlijk is MVC zo oud als de weg naar Rome, maar wordt het daar een slechter concept door?
Tja, ook als je een framework zoals cake gebruikt kan je er een ranzig onbegrijpelijk teringzooitje van maken. Je hebt ook wat ervaring nodig om je applicatie goed te kunnen ontwerpen, onafhankelijk van wat voor taal, framework, design model of techniek je ook gebruikt. Ik heb in het verleden met praktisch dezelfde software die ik nu nog wel gebruik, ook dingen gemaakt waarvan de tranen nu in mijn onderbroek springen. Dingen als MVC ga je pas echt gebruiken als je de nadelen ervaart van een niet goed ontworpen applicatie - als je een ratjetoe met alles door elkaar moet onderhouden, debuggen of uitbreiden zie je het belang en de logica van iets als MVC vanzelf wel in.quote:Het probleem wat ik bloot bedoelde te leggen met de traditionele template engines is dat PHP'ers daardoor alsnog een ratjetoe van code maken met alles door elkaar (database, logica, etc) om vervolgens alleen voor het tonen een template engine te gebruiken. MVC is absoluut "in", in de betekenis dat het steeds meer gebruikt wordt en je er (imo) nettere code door krijgt die beter te begrijpen is voor derden (convention over configuration enzo).
Niets, dat is precies wat ik bedoelde. Het is enkel een template engine die je alsnog een ranzige structuur toestaat.quote:Op donderdag 28 februari 2008 14:26 schreef Farenji het volgende:
Ik heb niet gezegd dat MVC een slecht concept is, integendeel, ik ben een grote fan van MVC. Maar wat is Smarty anders dan een template engine?
Dat ben ik met je eens, al vind ik wel dat een framework gebruiken er iig voor zorgt dat de conventies gevolgd worden en het (hopelijk) allemaal minder ranzig wordtquote:Tja, ook als je een framework zoals cake gebruikt kan je er een ranzig onbegrijpelijk teringzooitje van maken. Je hebt ook wat ervaring nodig om je applicatie goed te kunnen ontwerpen, onafhankelijk van wat voor taal, framework, design model of techniek je ook gebruikt. Ik heb in het verleden met praktisch dezelfde software die ik nu nog wel gebruik, ook dingen gemaakt waarvan de tranen nu in mijn onderbroek springen. Dingen als MVC ga je pas echt gebruiken als je de nadelen ervaart van een niet goed ontworpen applicatie - als je een ratjetoe met alles door elkaar moet onderhouden, debuggen of uitbreiden zie je het belang en de logica van iets als MVC vanzelf wel in.
Toch niet?quote:Op donderdag 28 februari 2008 13:20 schreef CraZaay het volgende:
Ah, interessant. Zoals welke opties? Ben niet nieuwsgierig
Ik heb ook wel eens engines gebruikt waar je alleen variabeles in kwijt kan. Dan blijven je templates lekker schoon en begrijpelijk (fijn voor de graficiquote:Op donderdag 28 februari 2008 14:59 schreef CraZaay het volgende:
[..]
Niets, dat is precies wat ik bedoelde. Het is enkel een template engine die je alsnog een ranzige structuur toestaat.
quote:Op zaterdag 1 maart 2008 20:09 schreef super-muffin het volgende:
Hoe kan ik RGB waardes omrekenen naar HEX?
1 2 3 | echo "<a href=' " . $_SERVER["PHP_SELF"] . "&p=2'>".($i+1)."</a>"; ?> |
RGB = drie getallen, niets meer en niets minder. En of je de waarden nou opschrijft als 255, 0xFF of als 0377 het blijven gewoon drie getallen tussen de 0 en de 255.quote:Op zaterdag 1 maart 2008 20:17 schreef Geqxon het volgende:
RGB is toch 0-255 0-255 0-255? Decimaal dus?
In je code staat PHP_SELF en in wat je eronder schrijft PHP-SELFquote:Op zaterdag 1 maart 2008 20:29 schreef broodmonkeh het volgende:
Korte vraag , jullie weten vast het antwoord wel:
[ code verwijderd ]
Krijgt als output: <a href='&p=2'>. Als ik $_SERVER['PHP-SELF'] bijv. echo dan krijg ik: www.pagina.nl/index.php?blaat=blaat . Hoe kan het dat ie hem niet weergeeft bij mijn link?
Ik ga maar is slapenquote:Op zaterdag 1 maart 2008 20:34 schreef Thomass het volgende:
[..]
In je code staat PHP_SELF en in wat je eronder schrijft PHP-SELF
Ook gebruik je in je code " en in wat je eronder schrijft '
probeer is $_SERVER['PHP_SELF'], zou moeten werken
1 2 3 4 5 6 7 8 9 | echo strtotime("now"), "\n"; echo strtotime("10 September 2000"), "\n"; echo strtotime("+1 day"), "\n"; echo strtotime("+1 week"), "\n"; echo strtotime("+1 week 2 days 4 hours 2 seconds"), "\n"; echo strtotime("next Thursday"), "\n"; echo strtotime("last Monday"), "\n"; ?> |
Handig functiequote:Op zondag 2 maart 2008 13:24 schreef Geqxon het volgende:
http://nl2.php.net/manual/en/function.strtotime.php ?
[ code verwijderd ]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | $path = "pics/"; // Foto's zoeken in directory en array vullen met de urls foreach (glob($path. "*") as $imagename) { $images[] = $imagename; } $maxfotos = count($images) - 1; $i = 1; $foto1 = "tempwaarde1"; $foto2 = "tempwaarde2"; $foto3 = "tempwaarde3"; while ($i < 4 ) { $foto = rand(0, $maxfotos); if ($i == 1) { $foto1= $foto; echo $foto1; } elseif ($i == 2) { $foto2= $foto; echo $foto2; } elseif ($i == 3) { $foto3= $foto; echo $foto3; } if (($foto1 == $foto2) || ($foto1 == $foto3) || ($foto2 == $foto3)) { } else { echo "<img src='$images[$foto]' border='0' height='80' /> "; $i++; } } ?> |
1 2 3 4 5 | $path = "pics/"; foreach(array_rand($x=glob($path. "*"), 3 ) as $foto) echo "<img src=\"{$x[$foto]}\" border=\"0\" height=\"80\" /> "; ?> |
ah kijk..dat wist ik als beginner nog niet. maar het werkt fantastisch dus bedankt!quote:Op dinsdag 4 maart 2008 20:14 schreef ralfie het volgende:
je doet echt veel te moeilijk, php heeft een speciale functie voor random acties op arrays, bijv
[ code verwijderd ]
Persoonlijke voorkeur? Multiline? Snelheid? Parsen van variabelen?quote:Op dinsdag 4 maart 2008 20:40 schreef Likkende_Lassie het volgende:
Ralfie, waarom echo " " doen en niet echo ' ' ?
Het mooiste is nog altijd een sprintf in combinatie met single-quotes.quote:Op dinsdag 4 maart 2008 21:10 schreef Likkende_Lassie het volgende:
Ik zie vaak dat mensen een dubbele quote gebruiken, maar vervolgens in de hele HTML slashes moeten gebruiken, er onhandig lijkt me toch??
1 2 3 | printf('<img src="%s" border="0" height="80">', $x[$foto]); ?> |
Waarom zou iemand het eigenlijk zo willen? Kan me ff niet zo snel een reden bedenken....quote:Op dinsdag 4 maart 2008 21:54 schreef Geqxon het volgende:
Direct een variabele in een string vind ik imho behoorlijk bah.
[ code verwijderd ]
Als het dan toch moet, vind ik dit het netste.
Zo dat ik de statische HTML en de dynamische variabelen in een enkel oogopslag kan onderscheiden. Daarnaast heb je geen ranzige constructies als het aan elkaar plakken van strings (nogmaals : mijn mening), en kun je ook data 'parsen'. Als ik geen %s maar %d had gedaan, dan zou op die plek enkel en alleen een integer kunnen staan. Makkelijk bij bijvoorbeeld 'index.php?id=%d'.quote:Op dinsdag 4 maart 2008 21:56 schreef Likkende_Lassie het volgende:
[..]
Waarom zou iemand het eigenlijk zo willen? Kan me ff niet zo snel een reden bedenken....
Farenji, logische reden ja
1 2 3 4 5 6 7 8 9 | $sql = sprintf("INSERT INTO mod_item (Parent_ID, Title, Content, View) VALUES('%d', '%s','%s','%s')", $input_parent['ID'], mysql_real_escape_string($input_title), mysql_real_escape_string($input_content), mysql_real_escape_string($input_view)); ?> |
Alsof dat ook maar iets uitmaakt, het feit dat je gewoon variabelen tussen tekst door kan typen is toch geweldig handig? Een beetje editor zorgt dan ook gelijk voor normale highlighting zodat het goed opvalt..quote:Op dinsdag 4 maart 2008 21:45 schreef Farenji het volgende:
Enkele quotes is sneller, omdat die niet geparsed hoeven te worden.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | function secureValue($value, $html){ if (!$html){ $value = strip_tags($value, '<b>,<a>,<i>,<u>,<img>'); }else{ $value = htmlnumericentities($value); } if (!$value){ $value = NULL; } switch (gettype($value)) { case 'boolean': return $value ? '1' : '0'; case 'integer': case 'double': return (string)$value; case 'string': return "'".addslashes($value)."'"; case 'array': case 'object': return "'".addslashes($value)."'"; default: //'resource', 'NULL', 'unknown type' return 'NULL'; die(); } } ?> |
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |