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()); |
Maak er eens SELECT DISTINCT * .... vanquote: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
heineken verwarren met grolschquote:Op vrijdag 2 mei 2008 13:38 schreef Light het volgende:
[..]
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.
Duidelijk gevalletje van ja, en zelfs tweequote:Op vrijdag 2 mei 2008 13:02 schreef Light het volgende:
[..]
[ code verwijderd ]
Je geeft aan sprintf 1 string en 2 andere parameters mee, terwijl er in die string maar 1 placeholder is. Gevalletje haakjes verkeerd?
Een simpele oplossing is:quote:Op vrijdag 2 mei 2008 14:10 schreef webbyplus het volgende:
Hallo, waarschijnlijk super simpel op te lossen, maar het lukt me niet;
Ik heb de volgende code:
[ code verwijderd ]
De STRING $test bevat 76 cijfers. Echter als ik hem nu echo krijg ik zoiets te zien : "1.0305006007E+047". Hoe kan ik mijn string correct tonen? bvd
1 2 | echo 0 + $test; |
Perl doet hetzelfdequote:Op vrijdag 2 mei 2008 16:49 schreef CraZaay het volgende:
[..]
Mooi he dat PHP... een int en een string bij elkaar optellen
quote:Op vrijdag 2 mei 2008 16:49 schreef CraZaay het volgende:
[..]
Mooi he dat PHP... een int en een string bij elkaar optellen
Das waar, maar echo (float) $test werkt ook, en is wellicht nog netter ookquote:Op vrijdag 2 mei 2008 17:10 schreef CraZaay het volgende:
[..]
JavaScript en allerlei andere loosely typed talen ook, maar dat maakt het nog niet netter
1 |
Ik zie niks verkeerd aan deze query om heel eerlijk te zijn. Maar toegegeven SQL is niet mijn sterkste ding.quote:Op zaterdag 3 mei 2008 14:16 schreef Dzy het volgende:
Ik heb een vraagje
Ik ben bezig met een site waar een heleboel gedichten op komen te staan van dezelfde dichter. Deze kan hij taggen met meerdere tags, die allemaal weer in een aparte tabel tags staan. Omdat er meerdere tags bij meerdere gedichten kunnen gebruik ik een koppeltabel gedichten_tags. Alleen hoe kan ik nu mooi in 1 query alle gedichten opvragen die bij 1 of meer tags horen?
Ik zat zelf al een beetje te prutsen met de volgende query:
[ code verwijderd ]
Dit zou dan alle gedichten opvragen die een tag hebben van 1, 3 of 4 maar de bedoeling is natuurlijk dat ze alle drie zo getagd moeten zijn. En voor mijn gevoel is dit een ranzige query, maar dat kan ik verkeerd hebben. Ingewikkelde queries ben ik nog niet zo goed inWie kan me helpen?
1 2 3 4 | WHERE gedichten.gedicht_id = gedichten_tags.gedicht_id AND gedicht_tags.tag_id IN (1,3,4) GROUP BY gedichten.gedicht_id HAVING COUNT(*) = 3 |
Zie andere topic :Pquote:
1 2 3 4 5 6 7 8 9 | FROM gedichten g WHERE g.gedicht_id IN ( SELECT t.gedicht_id FROM gedichten_tags t WHERE t.tag_id IN (1, 3, 4) GROUP BY t.gedicht_id HAVING COUNT(*) = 3 ) |
omfgquote:Op donderdag 1 mei 2008 18:20 schreef Flaccid het volgende:
Ik heb een functie met die checkt of een variable leeg is of niet, wanneer hij leeg is zegt hij dat hij leeg is. Maar dan wordt het: Hoe krijg je de tekst van een variable die leeg is op het scherm, dus de naam van de lege variable?
[ code verwijderd ]
1 2 3 4 5 6 7 8 | WHERE (g.gedicht_id IN ( SELECT t.gedicht_id FROM gedicht_tags t WHERE t.tag_id IN (1,2) GROUP BY t.gedicht_id HAVING COUNT(*) = 2) ) AND (g.gedicht_boekje = '3') |
Zover ik tot nog toe heb ondervonden duren dit queries (dus met querie in querie) langer dan een join.quote:Op zaterdag 3 mei 2008 15:34 schreef SuperRembo het volgende:
[..]
Zie andere topic
Het zou (uitgaande van MySQL 5) zo iets worden:
[ code verwijderd ]
Een subquery dusquote:
In dit geval lukt het ook wel zonder sub-query, alleen wordt 't daar wat minder overzichtelijk van. En de vraag is of 't echt sneller is.quote:Op zaterdag 3 mei 2008 16:40 schreef ursel het volgende:
Zover ik tot nog toe heb ondervonden duren dit queries (dus met querie in querie) langer dan een join.
1 2 3 4 5 6 7 | FROM gedichten g INNER JOIN gedichten_tags t ON t.gedicht_id = g.gedicht_id WHERE g.gedicht_boekje = 3 AND t.tag_id IN (1, 3, 4) GROUP BY g.gedicht_id, g.titel HAVING COUNT(*) = 3 |
Wat bedoel je daar precies mee?quote:Op zaterdag 3 mei 2008 16:56 schreef CraZaay het volgende:
Zijn er hier überhaupt mensen bezig met memcached en dergelijke?
Eigenlijk wat er staatquote:
Een project wat ik voor NU.nl gedaan heb bijvoorbeeld (da's extreem), maar ook een jongerensite met een sociaal netwerk wat met 30.000 pageviews per dag al aardig wat zware queries oplevert.quote:Op zaterdag 3 mei 2008 18:56 schreef Xcalibur het volgende:
Aan wat voor bezoekersaantallen / queries moet ik denken als jij het over een drukke site hebt?![]()
Waarom zou memcached hier niet geschikt voor zijn? In dat geval check ik in de model of het result in de cache zit, en zo niet voer ik de query uit en sla het resultaat op in de cache met een time to live van 24 uurquote:Op zondag 4 mei 2008 01:17 schreef Farenji het volgende:
Memcache gebruik ik niet zo vaak maar ik gebruik wel regelmatig sql caching, waar het resultaat van een loodzware query geserialized wordt opgeslagen in een objectstorage in de db. Aan memory caching heb je in dit geval minder omdat het om queries gaat waar het resultaat hoogstens 1 keer per dag wijzigt en je aan alle bezoekers hetzelfde resultaat wil tonen. Die wil je dus ook maar 1 keer per dag berekenen, niet meer.
punt 3 is alleen uit te lezen bij @home en nog een geloof ik. Bij planet (mijn ISP) wordt het niet meegestuurd. Je hebt wel databases die dat soort info verzamelen en waar je beroep op kunt doen, sommige gratis, sommige niet.quote:Op maandag 5 mei 2008 09:14 schreef Chandler het volgende:
Kleine vraag, stel ik heb een hostname cc93022-a.tu.nogwat.home.nl
Van deze hostname wil ik het volgende uitlezen (maar dit kan natuurlijk ook een andere hostname zijn)
- home.nl
- home
- @home internet Groningen Nederland (dit kun je ergens uitlezen maar waar?)
Is er voor de 1e 2 een regex die ook werkt met co.uk en dergelijke domeinnamen? en waar kan ik de 3e gegeven weg halen?
SELECT MAX(id) FROM gegevens ?quote:Op maandag 5 mei 2008 14:54 schreef wobbel het volgende:
Ik heb een tabel met Auto Increment, hoe krijg ik nu heel makkelijk het laatste ID eruit?
Nu doe ik namelijk SELECT id FROM gegevens ORDER BY id DESC LIMIT 1, maar kan dat niet sneller?
quote:Op maandag 5 mei 2008 15:11 schreef wobbel het volgende:
[..]
moet ik die dan weer opvragen met mysql_fetch_assoc of kan dat ook met mysql_result ofzo?
1 2 3 | $laatste = mysql_result(mysql_query("SELECT MAX(id) FROM gegevens"),0); ?> |
Goede tip zegquote:Op maandag 5 mei 2008 16:36 schreef SuperRembo het volgende:
Als je de id wil weten van de row die je net ge-insert hebt, dan kan je beter mysql_insert_id() gebruiken.
Die kende ik gelukkig alquote:Op maandag 5 mei 2008 16:36 schreef SuperRembo het volgende:
Als je de id wil weten van de row die je net ge-insert hebt, dan kan je beter mysql_insert_id() gebruiken.
1 2 3 4 | USING SHOP_Carts.IdCart LEFT JOIN SHOP_Cartcontents.CartId = SHOP_Carts.IdCart WHERE SHOP_Carts.IdCart = '1' |
quote:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '.IdCart WHERE SHOP_Carts.IdCart = '1'' at line 1
Moet het niet zijnquote:Op maandag 5 mei 2008 18:54 schreef wobbel het volgende:
[..]
Die kende ik gelukkig al ;)
Andere vraag: Ik heb onderstaande query, alleen daar is blijkbaar iets fout aan :P
[ code verwijderd ]
Foutmelding
[..]
1 |
Ik heb gezocht naar opties voor punt 3 (@home internet) maar kan helaas niets vindenquote:Op maandag 5 mei 2008 11:04 schreef qu63 het volgende:
[..]
punt 3 is alleen uit te lezen bij @home en nog een geloof ik. Bij planet (mijn ISP) wordt het niet meegestuurd. Je hebt wel databases die dat soort info verzamelen en waar je beroep op kunt doen, sommige gratis, sommige niet.
Op jou manier krijg ik de volgende fout:quote:
Dit is m'n query:quote:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'LEFT JOIN SHOP_Cartcontents on SHOP_Carts.IdCart = SHOP_Cartcontents.CartId WHER' at line 1
1 2 3 4 | LEFT JOIN SHOP_Cartcontents ON SHOP_Carts.IdCart = SHOP_Cartcontents.CartId WHERE SHOP_Carts.IdCart = '5' |
http://www.maxmind.com/app/cityquote:Op dinsdag 6 mei 2008 09:26 schreef Chandler het volgende:
[..]
Ik heb gezocht naar opties voor punt 3 (@home internet) maar kan helaas niets vindenwaarschijnlijk op de verkeerde woorden gezocht maar kun je me een linkje posten?
Waarom een left join in een delete statement?quote:Op dinsdag 6 mei 2008 11:46 schreef wobbel het volgende:
Dit is m'n query:
[ code verwijderd ]
Ik heb de MySQL reference guide er ook al bijgezocht, maar zelfs dan lukt het me nog niet :')
http://dev.mysql.com/doc/refman/5.0/en/delete.html
1 2 | WHERE SHOP_Carts.IdCart = '5' |
1 2 | WHERE SHOP_Cartscontents.IdCart = '5' |
quote:Op dinsdag 6 mei 2008 12:20 schreef ursel het volgende:
Misschien een knullige vraag, maar om 2 tabellen te mergen doe ik een select in een temp tabel en update ik de main tabel.
Nu doe ik een query met SELECT * FROM table. Maar eigenlijk wil ik alle kolommen hebben exclusief kolom ncID. Aangezien er +/- 15 kolommen zijn leek het mij eigenlijk onlogisch om elke kolom in de SELECT statement te plaatsen. Is er geen praktische manier om een specifieke kolom te excluden?
1 |
quote:Op dinsdag 6 mei 2008 12:28 schreef JortK het volgende:
[..]
[ code verwijderd ]
En dan niet de kolom ncID ertussen zetten?
quote:Op dinsdag 6 mei 2008 12:20 schreef ursel het volgende:
...
Aangezien er +/- 15 kolommen zijn leek het mij eigenlijk onlogisch om elke kolom in de SELECT statement te plaatsen. Is er geen praktische manier om een specifieke kolom te excluden?
Nou omdat ik dit wil uitvoeren eigenlijk:quote:Op dinsdag 6 mei 2008 12:07 schreef JortK het volgende:
[..]
Waarom een left join in een delete statement?
Je kan toch gewoon dit doen:
[ code verwijderd ]
En als je ook de content wil verwijderen:
[ code verwijderd ]
WHER of WHEREquote:Op dinsdag 6 mei 2008 11:46 schreef wobbel het volgende:
[..]
Op jou manier krijg ik de volgende fout:
Zoals je kon zien had ik de goede query er ook bijgezet, aangezien een MySQL foutmelding niet de gehele query teruggeeft. Ik had gewoon WHERE dusquote:
Zo dan:quote:Op dinsdag 6 mei 2008 13:23 schreef wobbel het volgende:
[..]
Zoals je kon zien had ik de goede query er ook bijgezet, aangezien een MySQL foutmelding niet de gehele query teruggeeft. Ik had gewoon WHERE dus ;)
1 2 | WHERE SHOP_Carts.Tijd < '250000' |
1 2 | WHERE SHOP_Cartcontents.CartID IN (SELECT CartID from SHOP_Carts WHERE SHOP_Carts.Tijd < '250000') |
Stomme vraag, moet ik die 2 query's apart uitvoeren of alleen de onderste?quote:Op dinsdag 6 mei 2008 13:40 schreef JortK het volgende:
[..]
Zo dan:
[ code verwijderd ]
[ code verwijderd ]
Lijkt mij allebei, de bovenste verwijderd je 'winkelwagen' de onderste je 'winkelwageninhoud'quote:Op dinsdag 6 mei 2008 14:21 schreef wobbel het volgende:
[..]
Stomme vraag, moet ik die 2 query's apart uitvoeren of alleen de onderste?
Goed gezien jaquote:Op dinsdag 6 mei 2008 15:44 schreef Intrepidity het volgende:
Wel andersom lijkt me, als je eerst die bovenste uitvoert levert de subquery in de onderste niks meer op
met ongeveer iets als dit:quote:Op woensdag 7 mei 2008 11:38 schreef Dzy het volgende:
Bovenaan z'n site in het menu staat "Contact me" :)
http://aruljohn.com/contact.php
En mocht je erachter zijn kun je het hier dan even posten? :)
Vraagje: Als ik een locatie op Googlemaps heb hoe kan ik daar dan de hoogte/breedtegraag van krijgen om google maps te integreren in een site van me?
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 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <title>Google Maps JavaScript API Example</title> if($_SERVER['SERVER_SOFTWARE'] == "Abyss/2.0.0.20-X2-Win32 AbyssLib/2.0.0.20"){$key = "ABQIAAAAplnifruwGrfwpWvbEV5auhS4B2hPn9jRGCWcnfTi9eR2TxbJAxRuquOiECed3a0MS8kKy014S0rXIg";}else{$key = "ABQIAAAAplnifruwGrfwpWvbEV5auhSKsMW_Q8n2eDtD9HmS6wzqCxy26xRijJuhQRwy1t661WeJIX7FqoSNPw";}echo '<script src="http://maps.google.com/maps?file=api&v=2&key='.$key.'" type="text/javascript"></script>' <script type="text/javascript"> var map; var gdir; var geocoder = null; var addressMarker; function locatie() { if (GBrowserIsCompatible()) { map = new GMap2(document.getElementById("map_canvas")); map.setCenter(new GLatLng(52.264680, 5.161900), 17); map.enableScrollWheelZoom(); map.addControl(new GScaleControl()); map.addControl(new GLargeMapControl()); GEvent.addListener(map, "click", function(geen,test) { document.getElementById("naar").value = test.toUrlValue().replace(/,/gi, ", "); }); } } function reken() { if (GBrowserIsCompatible()) { gdir = new GDirections(map, document.getElementById("directions")); GEvent.addListener(gdir, "load", onGDirectionsLoad); GEvent.addListener(gdir, "error", handleErrors); var van = document.getElementById("van").value; van = van.replace(/CS/gi, "Centraal Station") var naar = document.getElementById("naar").value naar = naar.replace(/CS/gi, "Centraal Station") var sp = document.getElementById("sp").value; if(document.getElementById("ms").checked) { setDirectionsSP(sp, van, naar, sp, "nl_NL"); } else { setDirections(van, naar, "nl_NL"); } } } function setDirections(fromAddress, toAddress, locale) { gdir.load("from: " + fromAddress + " to: " + toAddress, { "locale": locale }); } function setDirectionsSP(sp, fromAddress, toAddress, sp, locale) { gdir.load("from: " + sp + " to: " + fromAddress + " to: " + toAddress + " to: " + sp, { "locale": locale }); } function handleErrors(){ if (gdir.getStatus().code == G_GEO_UNKNOWN_ADDRESS) alert("No corresponding geographic location could be found for one of the specified addresses. This may be due to the fact that the address is relatively new, or it may be incorrect.\nError code: " + gdir.getStatus().code); else if (gdir.getStatus().code == G_GEO_SERVER_ERROR) alert("A geocoding or directions request could not be successfully processed, yet the exact reason for the failure is not known.\n Error code: " + gdir.getStatus().code); else if (gdir.getStatus().code == G_GEO_MISSING_QUERY) alert("The HTTP q parameter was either missing or had no value. For geocoder requests, this means that an empty address was specified as input. For directions requests, this means that no query was specified in the input.\n Error code: " + gdir.getStatus().code); // else if (gdir.getStatus().code == G_UNAVAILABLE_ADDRESS) <--- Doc bug... this is either not defined, or Doc is wrong // alert("The geocode for the given address or the route for the given directions query cannot be returned due to legal or contractual reasons.\n Error code: " + gdir.getStatus().code); else if (gdir.getStatus().code == G_GEO_BAD_KEY) alert("The given key is either invalid or does not match the domain for which it was given. \n Error code: " + gdir.getStatus().code); else if (gdir.getStatus().code == G_GEO_BAD_REQUEST) alert("A directions request could not be successfully parsed.\n Error code: " + gdir.getStatus().code); else alert("An unknown error occurred."); } function add() { document.getElementById("naar").value = document.getElementById("naar").value + " to:"; document.getElementById("naar").focus(); } function onGDirectionsLoad(){ var afstand = Math.round((gdir.getDistance().meters/1000)*10)/10; document.getElementById("reken").value = afstand + " km"; var sec = Math.round(gdir.getDuration().seconds/60); //document.getElementById("tijd").value = sec + " minuten"; if(sec == 60) { document.getElementById("tijd").value = "1 uur" + sec; } else if(sec > 60) { var test = sec/60; var uur = Math.floor(test); var minuten = sec - (uur * 60); document.getElementById("tijd").value = uur + " uur en " + minuten + " minuten"; } else { document.getElementById("tijd").value = sec + " minuten"; } var gem = Math.round(gdir.getDistance().meters/gdir.getDuration().seconds*3.6); document.getElementById("gem").value = gem + " km/h"; } </script> </head> <body onload="locatie()"> <table> <tr> <td> </td><td><input type="hidden" id="sp" value="701 @52.264680, 5.161900"><input type="checkbox" id="ms">Vanaf standplaats?</td><td><input type="text" id="van" value=""></td><td><input type="text" id="naar" value="" size="50"></td><td><input type="button" onclick="reken()"></td><td><input type="text" id="reken"></td><td><input type="text" id="tijd"></td><td><input type="text" id="gem"></td> </tr> <tr> <td>Voorbeeld:</td><td>Standplaats</td><td>Amsterdam Centraal Station</td><td>Hilversum to: Jaarbeursplein, Utrecht</td><td> </td><td> </td><td> </td><td> </td> </tr> <tr> <td> </td><td> </td><td> </td><td><a href="#" onclick="add()">bestemming toevoegen</a></td><td> </td><td> </td><td> </td><td> </td> </tr> <div id="totaal"></div> <div id="klant"></div> </table> <script type="text/javascript"> //document.write(startAddress); </script> <div id="map_canvas" style="width: 600px; height: 400px"></div> <!-- <div id="directions" style="width: 275px; height: 400px"></div> <div id="map_canvas" style="width: 70%; height: 480px; float:left; border: 1px solid black;"></div> <div id="route" style="width: 25%; height:480px; float:right; border; 1px solid black;"></div>--> </body> </html> ?> |
Check ook de site van WyriHaximus die heeft er ook aardig wat informatie opstaan.quote:Op woensdag 7 mei 2008 11:38 schreef Dzy het volgende:
Bovenaan z'n site in het menu staat "Contact me"
http://aruljohn.com/contact.php
En mocht je erachter zijn kun je het hier dan even posten?
Vraagje: Als ik een locatie op Googlemaps heb hoe kan ik daar dan de hoogte/breedtegraag van krijgen om google maps te integreren in een site van me?
als je nu naar maps.google.com gaat, een locatie opzoekt, en dan klikt op "link naar deze pagina", dan zie je in die url de coördinaten en het zoomniveau staan:quote:Op woensdag 7 mei 2008 11:58 schreef Dzy het volgende:
Key heb ik, maar het gaat erom dat ik bij maps.google.com bij een locatie de hoogte en lengtebreedte kan vinden zodat ik die kan integreren. Als ik bij die examples kijk staat er overal dit soort dingen:
map.setCenter(new GLatLng(37.4419, -122.1419), 13);
Daar gaat het me om, hoe bepaal ik van een bepaalde straat als ik die opzoek bij googlemaps wat de GLatLng moet zijn?
Lees dit eens, dit gaat over geocoding (het omzetten van een adres naar lat/long coördinaten) http://code.google.com/ap(...)vices.html#Geocodingquote:Op woensdag 7 mei 2008 11:58 schreef Dzy het volgende:
Key heb ik, maar het gaat erom dat ik bij maps.google.com bij een locatie de hoogte en lengtebreedte kan vinden zodat ik die kan integreren. Als ik bij die examples kijk staat er overal dit soort dingen:
map.setCenter(new GLatLng(37.4419, -122.1419), 13);
Daar gaat het me om, hoe bepaal ik van een bepaalde straat als ik die opzoek bij googlemaps wat de GLatLng moet zijn?
Altijd leukquote:Op woensdag 7 mei 2008 14:46 schreef Dzy het volgende:
Dank jullie allen voor de links, ik ben er al uitgekomen
Ik ga nu maar eens met cURL spelen om automagisch allerlei dingen van imdb te plukken en in mijn database te gooien zodat ik mooi links kan leggen tussen allerlei films in mijn collectie.
Bij dezequote:Op woensdag 7 mei 2008 11:38 schreef Dzy het volgende:
Bovenaan z'n site in het menu staat "Contact me"
http://aruljohn.com/contact.php
En mocht je erachter zijn kun je het hier dan even posten?
1 2 3 4 5 6 7 8 9 10 11 | $ch = curl_init(); echo curl_error($ch); curl_setopt($ch, CURLOPT_URL, "http://www.google.com/"); //movie PI curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)"); $output = curl_exec($ch); echo curl_error($ch); curl_close($ch); echo $output; ?> |
Waarschijnlijk moet je cookies meesturenquote:Op woensdag 7 mei 2008 19:48 schreef Dzy het volgende:
Hmm, hoe doen jullie dat met headers enzo sturen met curl? Als ik met cURL imdb probeer te openen geeft hij een 111 error, volgens google betekent dit dat hij geen connectie kan openen. Ik heb ook een paar andere pagina's geprobeerd te openen maar allen geven error 111. Dit is m'n code, ik doe toch niets fout of wel?
[ code verwijderd ]
Volgens phpinfo support mn host wel cURL:
CURL support enabled
CURL Information libcurl/7.10.6 OpenSSL/0.9.7a ipv6 zlib/1.1.4
Dus ik snap niet precies wat er mis is. Iemand?
1 2 | curl_setopt($ch, CURLOPT_COOKIEFILE, "cook"); |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | GET /title/tt0481536/ HTTP/1.1 Host: www.imdb.com User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.11) Gecko/20071127 Firefox/2.0.0.11 Accept: text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5 Accept-Language: en-us,en;q=0.5 Accept-Encoding: gzip,deflate Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 Keep-Alive: 300 Connection: keep-alive Cookie: cs=3uSEDutJagOs3OFX9fmfTA/+EDT6WFdifP3CJGjY9wH/yGBUL0AnYnHqV+pf+MPgb+hXYnlesCI/yFdiSd9X6n/IV1RH2N9ifdZ1YvjrR/b4nrEkL19RlX/IVyLf2BdCf+hXYn/IVyI/mBdSc=; uu=+mWv/hKNWfFsRJrmViWWKAronhA8qJ42rzudgD/b7UM/rt1DLyu9Bm+bvWN9z8lDGt7I4JyonhAPqx6wPAjdct/7vPNq3h6wfP/4lq5OeNCaLmjGaExesEwInrAYXFrUbAj7tU/afWMf6n0zLyu880877rD/2+0DT7u9AxyoPrCc6L4QO57IRtyonhB5n56YIfgKkiw8HA48qJ4QCw5+UByo2AbiRs4QPLgKkiyInhA8qJ5QfPjeID; session-id=613-0180128-2350691; session-id-time=1210266528 HTTP/1.x 200 OK Date: Wed, 07 May 2008 18:14:36 GMT Server: Server Set-Cookie: uu=grgE9OCRwbH3IQaed7gfHAronhA8qJ42rzudgD/b7UM/rt1DLyu9Bm+bvWN9z8lDGt7I4JyonhAPqx6wPAjdct/7vPNq3h6wfP/4lq5OeNCaLmjGaExesEwInrAYXFrUbAj7tU/afWMf6n0zLyu880877rD/2+0DT7u9AxyoPrCc6L4QOr5JttyonhB4KoHp/KieAKpI3jA876hGZLieED69qRCypc6EvJgKkiyInhA8qJ5QfPjeID;expires=Thu, 30 Dec 2037 00:00:00 GMT;path=/;domain=.imdb.com Set-Cookie: cs=accfTfBlqOPm1/G+Z8Z1YQH1umv2w+17xkvd83JB8mM2w+1LYEOtW/bD2zyhpZ179fRpbVZQrlhgVQo7VsPte8DU7fP2w+1NztNle/Tdz3tx4P3vcZULPaZU64z2w+07VtOtW/bj7Xv2w+07tpOtS/;expires=Thu, 08 May 2008 07:00:00 GMT;path=/;domain=.imdb.com Cache-Control: private Content-Type: text/html Vary: Accept-Encoding,User-Agent Content-Encoding: gzip Content-Length: 13154 nnCoection: close |
Waar slaat dat nou weer op? Curl is geschikt om o.a. GET, POST, PUT en DELETE requests uit te kunnen voeren, bijvoorbeeld om een RESTful interface te gebruiken. Hoe kom je erbij dat het vooral is om een formulier te posten?quote:Op woensdag 7 mei 2008 19:50 schreef qu63 het volgende:
en curl is vooral om een formulier te submitten (om bijvoorbeeld automatisch op fok te kunnen posten)
omdat ik het zo alleen gebruikquote:Op woensdag 7 mei 2008 20:40 schreef CraZaay het volgende:
[..]
Waar slaat dat nou weer op? Curl is geschikt om GET, POST, PUT en DELETE requests uit te kunnen voeren, bijvoorbeeld om een RESTful interface te gebruiken. Hoe kom je erbij dat het vooral is om een formulier te posten?
1 2 3 4 5 6 7 8 9 10 | echo curl_error($ch); $timeout = 5; // set to zero for no timeout curl_setopt ($ch, CURLOPT_URL, 'http://www.imdb.com/nowplaying/'); curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout); $file_contents = curl_exec($ch); echo curl_error($ch); curl_close($ch); echo $file_contents; |
ik krijg eenquote:Op donderdag 8 mei 2008 00:00 schreef Dzy het volgende:
Kan iemand anders proberen IMDB te benaderen via cURL? Ik heb een joomla extension gevonden waarin ze ook met cURL imdb aanspreken en daar stond alleen extra een regeltje curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout); bij, en ook daarmee deed hij het bij mij niet. Ik ben dus bang dat er bij mijn host iets niet helemaal goed zit. Dit is de volledige code die zou moeten werken:
[ code verwijderd ]
Ze hebben gewoon een firewall aanstaan dat al het verkeer via poort 80 naar buiten tegenhoudt.quote:Het is op onze machines niet meer mogelijk om externe URL's te 'includen' met Perl of met het PHP commando "fopen" of "curl" (allow_url_fopen). Het betreft hier uitsluitend http includes en connecties met het IRC en MSN netwerk.
Dit is gedaan in verband met de veiligheid van de aanwezige sites op deze servers, en voorkomt dat persoonlijke informatie zoals o.a. passwords makkelijk te verkrijgen is door hackers. Daarnaast kregen wij regelmatig klachten van website beheerders dat content zonder toestemming werd overgenomen en dat er via onze server getracht werd illegale activiteiten te ontplooien gebruikmakend van een Proxy-script (Als PHProxy), om zodoende de identiteit van de surfer te verbergen.
We verontschuldigen ons voor het onwaarschijnlijke geval dat u hinder ondervindt van deze configuratieaanpassing, echter hopen we dat u begrijpt dat deze aanpassing vrijwel uitsluitend voordelen heeft voor de beveiliging op de gehele server, en dat dit door ons ook niet per hostingpakket in te stellen is.
Overigens zijn er wel mogelijkheden om via html externe url's te includen. U doet dat door een zgn. "iframe" op te nemen, met daarin een directe link naar de pagina die u wilt includen. Zodoende loopt de include vanaf de server van de eigenaar zelf, en laadt daarnaast uw website veel sneller. (En het scheelt u dataverbruik).
Het openen van sockets via poort 80 is door de maatregel ook niet meer mogelijk. Wellicht kunt u gebruik maken van poort 81 of 443 voor https communicatie.
Bizar zeg. Ze gaan er vanuit dat je nooit een of andere API van een webservice wilt gebruiken?quote:Op donderdag 8 mei 2008 00:51 schreef Dzy het volgende:
Ze hebben gewoon een firewall aanstaan dat al het verkeer via poort 80 naar buiten tegenhoudt.
Ik heb er uitgebreid mee geëxpirimenteerd, dus het is zeker wel geïnstalleerdquote:Op donderdag 8 mei 2008 00:16 schreef Dzy het volgende:
Er is geen cURL geinstalleerd dan
Edit: Maar toch bedankt
Ja.quote:Op donderdag 8 mei 2008 08:39 schreef CraZaay het volgende:
[..]
Bizar zeg. Ze gaan er vanuit dat je nooit een of andere API van een webservice wilt gebruiken?
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 | /* Load main library Files */ require_once ( "lib/htconfig.php" ); require_once ( LIB_PATH . "/f_core.php" ); $path = BASE_PATH . "/include/upload/fck/voorkant.jpg"; $to = "wobbel@gmail.com"; $subject = "Test"; $body = "testberichtje"; $filename = "plaatje.jpg"; // Open te file $fp = @fopen ( $path, "r" ); // Check for errors if ( !$fp ) { die ( "Error #4" ); } // Grab file from server while ( !feof ( $fp ) ) { $file_content .= fread ( $fp , 1024 ); } // Close file fclose ( $fp ); // Encode file base 64 $file_content = chunk_split ( base64_encode ( $file_content ) ); // Create unique boundary using md5 $boundary = strtoupper ( md5 ( uniqid ( time ( ) ) ) ); // Create the headers $header .= "MIME-version: 1.0\n"; $header .= "Content-Type: multipart/mixed;\n"; $header .= "\tboundary= " . $boundary . "\n\n"; $header .= "This is a multi-part message in MIME format.\n\n"; // Creathe message body $header .= "--" . $boundary . "\n"; $header .= "Content-type: text/html; charset=iso-8859-1;\n"; // Adding the message to the body $header .= "De tekst in mijn email\n\n"; // Adding headers for the attachment $header .= "--" . $boundary . "\n"; $header .= "Content-Type: application/octet-stream; name=\"" . $filename . "\"\n"; $header .= "Content-Transfer-Encoding: base64;\n"; $header .= "Content-Disposition: attachment; filename=\"" . $filename . "\"\n\n"; // Add the attachment to the headers $header .= $file_content . "\n\n"; $header .= "--" . $boundary . "--"; // Send the e-mail mail ($to,$subject,"",$header); echo "verzonden..."; ?> |
Oke, ik heb nu dit...maar die leegt alsnog de hele tabel SHOP_Cartcontents, ongeacht de datum van SHOP_Carts.Datequote:Op dinsdag 6 mei 2008 14:23 schreef JortK het volgende:
[..]
Lijkt mij allebei, de bovenste verwijderd je 'winkelwagen' de onderste je 'winkelwageninhoud'
1 2 3 4 | mysql_query ( "DELETE FROM SHOP_Cartcontents WHERE SHOP_Cartcontents.CartID IN (SELECT CartID from SHOP_Carts WHERE SHOP_Carts.Date < '1210246772')" ) or die ( mysql_error ( ) ); mysql_query ( "DELETE FROM SHOP_Carts WHERE Date < '1210246772'" ) or die ( mysql_error ( ) ); ?> |
Is er een reden dat je zelf bijlagen wilt versturen? Anders kun je beter phpMailer gebruiken. Die kan ook bijlagen versturen en nog veel meer stoere dingenquote:Op donderdag 8 mei 2008 12:42 schreef wobbel het volgende:
Ik heb een script dat bijlagen verzend, maar die werkt niet helemaal goed
De bijlagen komen in Mozilla Thunderbird wel goed binnen, alleen Gmail ziet ze als beschadigd...en sommige andere e-mail clients vreten hem ook niet
Dit is de code:
[ code verwijderd ]
BASE_PATH is gewoon goed gedefinieerdalleen de bestanden die ik binnenkrijg zijn allemaal beschadigd
Bestandsgrootte's kloppen wel ongeveer
Als ik het goed begrijp kan SOAP alleen met HTTP authenticatie overweg, de rest zal je dus in de soap-server moeten oplossen. Wat ik dus gedaan heb, en dat lijkt allemaal te werkenquote:Op vrijdag 9 mei 2008 08:21 schreef Xcalibur het volgende:
Ik heb pas een mooie SOAP/XML server gemaakt met NuSOAP, met een aantal bijbehorende clients. Hartstikke leuk, en het werkt ook prima... Deze data is natuurlijk voor iedereen beschikbaar, dus nu krijg ik alleen de vraag of er ook een authorisatie mechanisme kan komen. Dus dat je eerst moet inloggen, voordat je de data krijgt.
In NuSOAP heb ik wel de functie SetCredentials() gevonden, waarmee je dus je username en password kan zetten. Wat ik alleen niet begrijp is waartegen deze gechecked worden... Moet ik een functie maken die de inloggegevens met de database vergelijkt, is dit een HTTP authenticatie, etc. ?
Wie weet raad?
1 2 3 4 5 6 7 | $limit = 50000; $num_records = $db->result('SELECT COUNT(id) FROM stat_info'); if ($num_records > $limit) { $db->query('DELETE FROM stat_info ORDER BY date ASC LIMIT '.($num_records-$limit)); } ?> |
Volgens mij gaat de delete-query mis, omdat date een keyword is in MySQL. Daar zou je dan backtics omheen moeten zetten, dus `date`. Nog mooier is het om geen keywords als kolomnamen te gebruikenquote:Op maandag 12 mei 2008 13:26 schreef wipes66 het volgende:
kan iemand voor mij verifieren dat deze query alleen de oude gegevens verwijdert? Het is zo lullig als er belangrijke gegevens verloren gaan door mijn gepruts![]()
![]()
[ code verwijderd ]
Als je DELETE even vervangt door SELECT *, dan kun je zien wat er allemaal verwijderd gaat worden.quote:Op maandag 12 mei 2008 13:26 schreef wipes66 het volgende:
kan iemand voor mij verifieren dat deze query alleen de oude gegevens verwijdert? Het is zo lullig als er belangrijke gegevens verloren gaan door mijn gepruts![]()
![]()
[ code verwijderd ]
Het is wel een keyword. Maar voor dit specifieke geval heb je inderdaad geen backticks nodig. Dat zegt de MySQL documentatie.quote:Op maandag 12 mei 2008 13:40 schreef Farenji het volgende:
Nee hoor, date is geen keyword, als kolomnaam heb je geen backticks nodig. Deze query moet gewoon goed gaan. En ja, hij wist alleen oude records.
quote:Op maandag 12 mei 2008 13:26 schreef wipes66 het volgende:
kan iemand voor mij verifieren dat deze query alleen de oude gegevens verwijdert? Het is zo lullig als er belangrijke gegevens verloren gaan door mijn gepruts![]()
![]()
[ code verwijderd ]
1 |
of als er 50001 records zijn blijft er nog maar 1 record over.quote:Op maandag 12 mei 2008 14:18 schreef SuperRembo het volgende:
[..]
Als dit script twee maal tegelijk wordt uitgevoerd bestaat (theoretisch) de kans dat je alle records verwijderd. Waarom niet gewoon zo?
[ code verwijderd ]
Foutje. De nieuwste 50000 moeten natuurlijk blijven staan, niet de oudste. Dus ORDER BY date DESC niet ASC.quote:Op maandag 12 mei 2008 14:23 schreef qu63 het volgende:
[..]
of als er 50001 records zijn blijft er nog maar 1 record over.
1 2 3 4 5 6 7 | $limit = 50000; $num_records = $db->result('SELECT COUNT(id) FROM stat_info'); if ($num_records > $limit) { $db->query('DELETE FROM stat_info ORDER BY date DESC LIMIT ?,?',array($limit,$num_records)); } ?> |
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |