Strings moeten tussen aanhalingstekens, getallen niet. Of nouja, MySQL maakt zich er niet zo druk om als je wel aanhalingstekens om getallen zet, maar het is netter om het niet te doen. En een IP-adres is geen getal maar een string, dus moet aanhalingstekens.quote:Op maandag 28 april 2008 00:33 schreef Igen het volgende:
Sowieso moet je de waarden tussen 'aanhalingstekentjes' zetten. Doe je dat niet, dan denkt MySQL dat het een kolom-naam is - en een IP-adres is uiteraard geen geldige naam voor een kolom...
In het voorbeeldje van Interpidity is dit trouwens al verbeterd.
1 2 3 4 5 | LEFT JOIN SHOP_Products_Lang ON SHOP_Products_Lang.ProductId = SHOP_Products.IdProduct LEFT JOIN SHOP_Afbeeldingen ON SHOP_Afbeeldingen.ProductId = SHOP_Products.IdProduct WHERE SHOP_Products.SubcategoryId = '1' AND SHOP_Products_Lang.LanguageId = '1' |
GROUP BY is your best friendquote:Op dinsdag 29 april 2008 13:50 schreef wobbel het volgende:
Oke, na wat geworstel heb ik aan de hand van dit topic de volgende query gekregen:
[ code verwijderd ]
Het probleem is nu alleen, dat als één artikel meerdere afbeeldingen heeft, het product ook meerdere keren erin komt te staan.
Stel ik heb 3 producten, en 1tje heeft 2 plaatjes, eentje heeft 3 plaatjes en de ander heeft 5 plaatjes...dan krijg ik deze output
Product 1
Product 1
Product 2
Product 2
Product 2
Product 3
Product 3
Product 3
Product 3
Product 3
Maar hij moet gewoon Product 1, Product 2 en Product 3 weergeven
Ik heb session_start() helemaal bovenaan staan.quote:Op dinsdag 29 april 2008 13:37 schreef slacker_nl het volgende:
Note: If you are using cookie-based sessions, you must call session_start() before anything is outputted to the browser.
Gebruikt je cookie based sessions?
1 2 | session_start(); |
Ligt er aan wat je wil laten zien. Als je bij elk product een wisselend aantal plaatjes wilt laten zien, dan zal je het in php moeten oplossen. Als je geen plaatjes wil laten zien, waarom join je dan tegen de afbeeldingen tabel? Als je per product 1 plaatje wil laten zien dan moet je de query aanpassen, maar hoe hangt er weer van af welk plaatje je wil laten zien.quote:Op dinsdag 29 april 2008 13:50 schreef wobbel het volgende:
Oke, na wat geworstel heb ik aan de hand van dit topic de volgende query gekregen:
[ code verwijderd ]
Het probleem is nu alleen, dat als één artikel meerdere afbeeldingen heeft, het product ook meerdere keren erin komt te staan.
Stel ik heb 3 producten, en 1tje heeft 2 plaatjes, eentje heeft 3 plaatjes en de ander heeft 5 plaatjes...dan krijg ik deze output
[...]
Maar hij moet gewoon Product 1, Product 2 en Product 3 weergeven
1 2 3 4 | RewriteCond %{HTTP_REFERER} !^http://(.+\.)?123swets\.com/ [NC] RewriteCond %{HTTP_REFERER} !^$ RewriteRule .*\.(jpe?g|gif|bmp|png)$ /image/hotlink.gif [L] |
Ik zou hoe dan ook eerst de referer checken op ^$ want en daarna pas je ^123swets.com$. Het is logischer om te checken of de referer bestaat en om dan te checken of het uit het 123swets.com domain komt. Maar dat heeft wellicht niks met je probleem te maken. Of misschien ook wel:quote:Op woensdag 30 april 2008 13:24 schreef Swetsenegger het volgende:
.htaccess probleempje
[ code verwijderd ]
hotlinking wordt wel geblokkeerd, maar alternatieve image wordt niet getoont. Wat doe ik fout?
Volgens mij komt dat door de [NC] en de volgorde van de checks. Als de referer leeg is moet ie de check skippen, maar omdat je eerst checked of het vanuit swets123.com komt en dan door de NC ervoor zorgt dat ie de originele URL weer gaat reprocesses en je dus zorgt voor een loop in je rewrites.quote:Firefox has detected that the server is redirecting the request for this address in a way that will never complete.
klinkt niet zo heel raar neequote:Op woensdag 30 april 2008 14:59 schreef Swetsenegger het volgende:
Hij blokkeerde mijn hotlink image ookDie moet je andere extensie geven dan de fileextensies die je blokkeert
quote:Op woensdag 30 april 2008 14:59 schreef Swetsenegger het volgende:
Hij blokkeerde mijn hotlink image ookDie moet je andere extensie geven dan de fileextensies die je blokkeert
1 2 3 4 5 | RewriteCond %{HTTP_REQUEST} !^/image/hotlink.gif RewriteCond %{HTTP_REFERER} !^$ RewriteCond %{HTTP_REFERER} !^http://(.+\.)?123swets\.com/ [NC] RewriteRule .*\.(jpe?g|gif|bmp|png)$ /image/hotlink.gif [L] |
Dan moet ie een 404 geven ipv een 403 forbidden (Konqueror) en geen redirect errors (FF/Safari).quote:Op woensdag 30 april 2008 15:37 schreef Swetsenegger het volgende:
hotlink.gif bestaat nu niet meer. het is nu hotlink.jpe
ik zie je hotlink plaatje nuquote:
MIjn 404 en 403 verwijst naar de index pagina. Ik heb hier geen errors. Misschien cache?quote:Op woensdag 30 april 2008 15:40 schreef slakkie het volgende:
[..]
Dan moet ie een 404 geven ipv een 403 forbidden (Konqueror) en geen redirect errors (FF/Safari).
1 2 3 4 5 6 | $part = trim($part); $part = strip_tags($part); $part = str_replace("\t", "", $part); $part = str_replace(" ", "", $part); ?> |
Zijn het geen linefeeds of carriage returns?quote:Op woensdag 30 april 2008 20:19 schreef Piles het volgende:
Ik zit met een heel raar probleem, vind ik zelf. Ik heb een html-bestand met daarin allerlei tabs en spaties. Die wil ik er uit hebben. Ik probeer dit:
[ code verwijderd ]
Alle spaties tussen woorden e.d. verdwijnen, maar toch blijven er nog een heleboel over. Wat voor 'soort' spaties kunnen dat zijn, en hoe krijg ik ze weg
1 2 3 | $string = str_replace(array("\t", ''), '', $string); ?> |
quote:Op woensdag 30 april 2008 20:25 schreef JortK het volgende:
Zijn het geen linefeeds of carriage returns?
1 2 3 | $part = trim( preg_replace( '/\s+/', ' ', $part) ); ?> |
Veranderd niks aan de situatiequote:Op woensdag 30 april 2008 20:26 schreef CraZaay het volgende:
Zijn het spaties in de broncode ("view source")? Dit kan overigens ook:
[ code verwijderd ]
Dat snap ik, het ging me vooral om het DRY-karakter en het gebruik van dubbele/enkele quotes.quote:
1 2 3 4 5 6 7 | function checkempty($var){ if(empty($var) ){ echo "$var niet ingevoerd"; } } ?> |
1 2 3 4 5 6 7 8 9 | function ce($var,$dn){ if(empty($var) ){ echo $dn." niet ingevoerd"; } } ce($name,'naam') ?> |
Kan ook, maar wat SuperRembo zegt klopt, ik wil eigenlijk een userfriendly name eruit hebben. Dus nu nog een manier vinden om 10 waardes in te voeren. Ik kan het handmatig doen, dan heb ik 10 regels code. kan het slimmer?quote:Op donderdag 1 mei 2008 18:36 schreef Intrepidity het volgende:
$var is de naam van de variabele toch al?
als je checkempty("blaat") aanroept moet ie checken of $blaat leeg is lijkt me toch?
dan is het
if(empty($$var))
{
// $var nu outputten.. $var uit $$var word dus omgezet naar "blaat" --> $blaat
}
1 2 3 4 5 6 7 8 9 | foreach(not_set( array('var1'=>'naam','var2'=>'lft','var3'=>'tijd','var4'=>'geslacht') as $var ) echo "hee dombo, je hebt '$var' niet gezet!"; function not_set($arr) { $out=array(); foreach($arr as $v=>$x) if(empty($GLOBALS[$v])) $out[]=$x; return $out; } ?> |
Mmm, dat soort code kan ik allemala nietquote:Op donderdag 1 mei 2008 23:05 schreef ralfie het volgende:
umm, waarom niet gwoon een arraytje?
[ code verwijderd ]
mss niet grammaticaal correct, maar het idee klopt toch?
Of gebruik func_get_args() icm met count (of func_num_args()).quote:Op donderdag 1 mei 2008 19:15 schreef SuperRembo het volgende:
Je kunt een functie maken waar je een willekeurig aantal parameters aan mee kunt geven; steeds afwisselend een var en een naam. Daarvoor gebruikt je func_get_arg().
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 | function is_empty() { $args = func_get_args(); $result = array(); if (count($args)) { foreach($args as $v) { if (is_array($v)) { $result = array_merge($result, call_user_func_array(__FUNCTION__, $v)); } else { if (empty($GLOBALS[$v])) { $result[] = $v; } } } return $result; } trigger_error(sprintf("%s requires at least 1 parameter\n", __FUNCTION__), E_USER_NOTICE); return $result; } function is_empty_2defaults() { $result = array(); if (func_num_args()) { $args = func_get_args(); foreach($args as $v) { if (!is_array($v)) { continue; } $tmp = is_empty(array_keys($v)); foreach($tmp as $v2) { $GLOBALS[$v2] = $v[$v2]; } $result = array_merge($result, $tmp); } } else { trigger_error(sprintf("%s requires at least 1 parameter\n", __FUNCTION__), E_USER_NOTICE); } return $result; } $test = "test"; $leeg = '0'; $niks = null; $weer_niks; $array = array(); print_r(is_empty("test")); print_r(is_empty("test", "leeg", "niks", "weer_niks", "array")); # Recursieve arrays print_r(is_empty(array(array(0)))); # En als je met hashes gaat werken: $hash = array("var1" => "leeg"); print_r(is_empty(array_values($hash))); # Maar dit mag ook: print_r(is_empty($hash)); $hash = array("glas" => "half vol"); $tmp = is_empty(array_keys($hash)); foreach($tmp as $v) { printf("%s is maar %s", $v, $hash[$v]); } # Als je default waardes wilt hebben voor de lege velden... $hash_defaults = array("user" => "guest", "password" => "guest"); is_empty_2defaults($hash_defaults); printf("User: %-8s\tPassword: %s\n", $user, $password); ?> |
quote:Op vrijdag 2 mei 2008 05:00 schreef slakkie het volgende:
Heb er maar een recursieve functie van gemaakt, accepteerd zowel arrays, als losse scalars. Persoonlijk zou ik er ook nog check bijgooien om te zien of $GLOBALS[$v] ook gelijk is aan 0 aangezien dat ook een boolean value kan zijn.
[ code verwijderd ]
1 2 3 | trigger_error(sprintf("%s requires at least 1 parameter\n", __FUNCTION__, E_USER_NOTICE)); ?> |
Waarom zou je dat überhaupt willen? Als je bij de beker het drank_id opslaat dan kun je altijd de drank_naam weer achterhalen.quote:Op vrijdag 2 mei 2008 12:57 schreef boskameel het volgende:
Stel je voor: Ik heb een klasse die beker heet, en ik heb een klasse die drank heet.
In de klasse beker heb je de volgende vars:
beker_id
beker_inhoud
beker_materiaal
beker_drank
Daarnaast heb ik de klasse drank, met daarin de volgende vars
drank_id
drank_naam
Ik wil een nieuwe beker aanmaken, want ik heb dorst. In het veld beker_drank van de klasse beker komt een waarde, een getal. Dit getal moet overeenkomen met drank_id uit de klasse drank. Wanneer deze overeenkomt, moet de inhoud van drank_naam worden ingevuld in het veld beker_drank. Ik denk dat het wel mogelijk is, maar hoe doe ik dit dan?
Misschien met foreign keys?quote:Op vrijdag 2 mei 2008 13:05 schreef Light het volgende:
[..]
Waarom zou je dat überhaupt willen? Als je bij de beker het drank_id opslaat dan kun je altijd de drank_naam weer achterhalen.
Dan maak je een JOIN over die twee tabellen, als je tenminste wilt weten welke drank er in een beker zit. Zo'n id is een makkelijk, vast punt. Ander voordeel is dat als je "bier" wilt vervangen door "Heineken" (om verwarring met "Grolsch" te voorkomen bijvoorbeeld) dan hoef je dat maar op 1 plek aan te passen.quote:Op vrijdag 2 mei 2008 13:23 schreef boskameel het volgende:
Als ik bv gebruik maak van een database, en een tabel beker en drank heb. Of denk ik nu te moeilijk?
Ja, dan moet je dus die ID's laten staan en niet ineens ID's door namen gaan vervangen. Da's niet logisch. Dat het in PHP kan, komt alleen maar omdat het loosely typed is.quote:
1 2 | echo $test; |
ai ik zie het al, zit met de verkeerde var te spelenquote:Op vrijdag 2 mei 2008 14:14 schreef CraZaay het volgende:
Die code toont bij mij gewoon je string. Als integer (zonder quotes dus) komt 'ie dichter bij jouw weergave in de buurt (1.0305006007E+77).
Hier ook..quote:Op vrijdag 2 mei 2008 14:14 schreef CraZaay het volgende:
Die code toont bij mij gewoon je string. Als integer (zonder quotes dus) komt 'ie dichter bij jouw weergave in de buurt (1.0305006007E+77).
Kan drank bestaan zonder beker?quote:Op vrijdag 2 mei 2008 12:57 schreef boskameel het volgende:
Stel je voor: Ik heb een klasse die beker heet, en ik heb een klasse die drank heet.
In de klasse beker heb je de volgende vars:
beker_id
beker_inhoud
beker_materiaal
beker_drank
Daarnaast heb ik de klasse drank, met daarin de volgende vars
drank_id
drank_naam
Ik wil een nieuwe beker aanmaken, want ik heb dorst. In het veld beker_drank van de klasse beker komt een waarde, een getal. Dit getal moet overeenkomen met drank_id uit de klasse drank. Wanneer deze overeenkomt, moet de inhoud van drank_naam worden ingevuld in het veld beker_drank. Ik denk dat het wel mogelijk is, maar hoe doe ik dit dan?
1 2 3 4 | $flesje = new fles($drankje->get_contents()) $bekertje = new beker(); $bekertje->vul($flesje->get_contents()); |
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |