Shopsystem ShopPilot Shoploesung Diskussionen und Infos zum Shopsystem ShopPilot
Willkommen Gast. Bitte einloggen oder registrieren.
Mai 23, 2012, 07:24:26

Einloggen mit Benutzername, Passwort und Sitzungslänge
Suche:     Erweiterte Suche
5257 Beiträge in 1422 Themen von 333 Mitglieder
Neuestes Mitglied: pje
* Übersicht Hilfe Login Registrieren
+  Diskussionen und Infos zum Shopsystem ShopPilot
|-+  ShopPilot
| |-+  SSP - Shop Server Pages
| | |-+  STAFM2 - Anzahl begrenzen 1 oder 0 abfragen
0 Mitglieder und 1 Gast betrachten dieses Thema. « vorheriges nächstes »
Seiten: [1] Drucken
Autor Thema: STAFM2 - Anzahl begrenzen 1 oder 0 abfragen  (Gelesen 1080 mal)
dobra
Global Moderator
Hero Member
*****

Lob: 18
Offline Offline

Beiträge: 1182


WWW
« am: Februar 25, 2009, 23:39:15 »

Hallo,

ich habe ein kleines Scrips gebastelt, daß länger als x Tage abgelaufene Gutscheine automatisch löscht.

Code:
<!--spmacro:module(loesche)
sub abgelaufeneGS{
my $tage = 14;  ## Gutscheine die länger als $tage abgelaufen sind löschen
my $jetzt = time();
my $loeschen = $jetzt - ($tage*24*60*60); # 60 Tage * 24 h * 60 min * 60 sec
my $ITEM = ssp::db_get_prefix() . "ITEM ";
my $read = ssp::readSQLData("SELECT ITEMID, PGID FROM $ITEM WHERE (STAFP4 < '$loeschen' && ITEMID Like '_GS_%')", "ITEMID", "PGID");  ## Gutscheinpräfix anpassen wenn nicht _GS_
for (my $i = 0; $i < $read; $i++) {
        my $artikelnr = ssp::get_var_db("ITEMID", $i);
        my $pagenr = ssp::get_var_db("PGID", $i);
ssp::db_delete_item(0,"$artikelnr",$pagenr); ## liegen die Gutscheincodes nur auf einer Seite, kann die Seitennummer auch fix eingetragen werden
}
}
-->

das ist unter verschiedenen Bedingungen getestet und funktioniert tadellos.

ich komme aber nicht drauf, wie ich auch eingelöste GS löschen kann  Sad

wird die Option "Anzahl begrenzen" aktiviert, steht das ja im STAFM2 Feld als 1:x:0  (x = sichtbar oder nicht und die 3. Zahl noch ohne Bedeutung)
in STAFP2 steht dann die noch verfügbare Anzahl bzw "0" wenn alle verfügbaren GS eingelöst wurden.
Ist die Option nicht aktiviert, ist das Feld STAFP2 leer.

und genau damit habe ich Probleme bei der Abfrage....

Wenn ich das Feld mit main::mprint ausgebe, bekomme ich "0" oder "nichts"
bei der Abfrage
WHERE STAFP2 =0 (hab's auch mit STAFP2 ='0' , STAFP2 =='0' und (LENGTH(STAFP2) >0 && STAFP2 =0) versucht)
wird aber kein Unterschied zwischen "nichts" und "0" gemacht und auch die GS gelöscht, die keine Begrenzung der Anzahl aktiviert haben (also das Feld leer ist).

Ich müsste also vermutlich WHERE (STAFM2 = Anzahl begrenzen aktiviert && STAFP2 =0) abfragen, aber WIE kann ich das STAFM2 Feld nach der ersten Zahl bei 1:x:0 abfragen?
=~ /1/ geht ja nicht, weil auch die 2. Zahl "1" sein kann...
Gespeichert

cru
Jr. Member
**

Lob: 7
Offline Offline

Beiträge: 69


« Antwort #1 am: Februar 26, 2009, 09:35:39 »

Hallo dobra,

also mit

Code:
WHERE STAFP2 NOT LIKE "%0%" AND STAFP2 = "";

bekommen Sie alle Artikel in deren STAFP2 Feld keine 0 steht, das Feld aber leer ist.

mit

Code:
WHERE STAFP2 LIKE "%0%" AND STAFP2 <> "";

bekommen Sie wiederrum Artikel in deren STAFP2 Feld eine 0 vorkommt und kein Leerstring!

mit

Code:
WHERE STAFP2 = "0" AND STAFP2 <> "";

bekommen Sie alle Artikel, bei denen nur die 0 im Feld steht und kein Leerstring!


Hilft das weiter?

mfg
cru

Gespeichert
dobra
Global Moderator
Hero Member
*****

Lob: 18
Offline Offline

Beiträge: 1182


WWW
« Antwort #2 am: Februar 26, 2009, 09:53:48 »

Hallo cru,

Danke - SO funktioniert die Abfrage   Cheesy
Gespeichert

Seiten: [1] Drucken 
« vorheriges nächstes »
Gehe zu:  

mysitelist Impressum Powered by SMF 1.1.16 | SMF © 2006, Simple Machines Prüfe XHTML 1.0 Prüfe CSS