php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > PHP Developer Forum
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Fragen zu Laravel, YII oder anderen PHP-Frameworks.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 31-01-2007, 15:28
cgdesign
 Newbie
Links : Onlinestatus : cgdesign ist offline
Registriert seit: Nov 2006
Beiträge: 29
cgdesign ist zur Zeit noch ein unbeschriebenes Blatt
Standard verzwickter Vergleich von 3 Werten

Hallo, ich joine 3 Tabellen und lese nun ua. 3 Werte aus, die ich vergleichen will.

Preis A = Spalte 1 = immer Preis enthalten
Preis B = Splate 2 = leer oder mehr enthalten
Preis C = Spalte 3 = leer oder mehr enthalten

Jetzt will ich Preis A mit den anderen beiden Preisen vergleichen.

Dabei soll Preis A rot markiert werden, wenn:
- Preis B oder C nicht leer ist und dann mindestens einer von Preis B oder C kleiner ist als Preis A

Hier mal eine anschauliche Grafik so wie es aussehen soll:


Versucht hab ich es so, warum auch immer:
Dabei ist row[2] = Preis A
row[9] = Preis B
row[14] = Preis C

PHP-Code:
if(empty($row[9]) and empty($row[14]))
{
    echo 
$row[2];
}
else
{
    if((!empty(
$row[9]) >= $row[2]) and (!empty($row[14]) <= $row[2]))
    {
        echo 
"<span style='color:red'>".$row[2]."</span>";
    }
    elseif((!empty(
$row[9]) <= $row[2]) and (!empty($row[14]) >= $row[2]))
    {
        echo 
"<span style='color:red'>".$row[2]."</span>";
    }
    else
    {
        echo 
$row[2];
    }

Nur funktioniert es natürlich nicht... jetzt wird alles rot angezeigt ausser die, wo in beiden Spalten nichts drin steht. Wo sind da meine Fehler?
Mit Zitat antworten
freelancermap.de - IT Projektvermittlung für Selbständige und Freiberufler
  #2 (permalink)  
Alt 31-01-2007, 15:34
penizillin
 PHP Guru
Links : Onlinestatus : penizillin ist offline
Registriert seit: Feb 2004
Beiträge: 10.166
penizillin ist zur Zeit noch ein unbeschriebenes Blatt
Standard

((!empty($row[9]) >= $row[2]) ist ja auch unsinn. was hat empty für einen rückgabewert? warum vergleichst du diesen mit einem zahlenwert? das sind zwei paar schuhe und sollten ensprechend separat abgefragt werden.
Mit Zitat antworten
  #3 (permalink)  
Alt 31-01-2007, 15:41
cgdesign
 Newbie
Links : Onlinestatus : cgdesign ist offline
Registriert seit: Nov 2006
Beiträge: 29
cgdesign ist zur Zeit noch ein unbeschriebenes Blatt
Standard

@penizillin

Also entweder steht in der Spalte was drin oder die Spalte ist "leer". Deswegen prüfe ich vorher noch mit "! empty" ob was drin steht oder nicht. Und ich will ja nur "nicht-leere" Werte überprüfen und vergleichen. Deswegen hab ich geprüft, ob der nicht-leere Wert von row[9] größer-gleich als row[2] ist. Ist das denn verkehrt? Ok, gehen tut es am Ende so oder so nicht...
Mit Zitat antworten
  #4 (permalink)  
Alt 31-01-2007, 15:44
arkos
 PHP Senior
Links : Onlinestatus : arkos ist offline
Registriert seit: Feb 2003
Ort: hamburg
Beiträge: 1.015
arkos ist zur Zeit noch ein unbeschriebenes Blatt
Standard

richtig. also zwei ansätze.... warum ist der defaultwert der db nicht "0"? somit kannst den kram mit empty vergessen und rein mathematisch vergleichen. oder du setzt innerhalb deine abfrag empty=0... so ungefähr:

PHP-Code:
i
if(empty($row[9]) and empty($row[14]))  //Preis B oder C nicht leer
{
    echo 
$row[2];
}
else
{
    if (empty(
$row[9])) $row[9]=0;
    if (empty(
$row[14])) $row[14]=0;
    if(
$row[9] <= $row[2] or $row[14] <= $row[2])
    {
        echo 
"<span style='color:red'>".$row[2]."</span>";
    }
    else
    {
        echo 
$row[2];
    }

__________________
**********
arkos
**********
Mit Zitat antworten
  #5 (permalink)  
Alt 31-01-2007, 15:45
XGremliN
 PHP Senior
Links : Onlinestatus : XGremliN ist offline
Registriert seit: Sep 2003
Ort: Karl-Marx-Stadt
Beiträge: 1.900
XGremliN ist zur Zeit noch ein unbeschriebenes Blatt
Standard

du meinst sicherlich:
PHP-Code:
if(!empty($row[9]) {
if(
$row[9] >= $row[2]) {
...}

OffTopic:
Mist! Zu langsam.
__________________
it's not a bug,
it's a feature!
Mit Zitat antworten
  #6 (permalink)  
Alt 31-01-2007, 15:46
cgdesign
 Newbie
Links : Onlinestatus : cgdesign ist offline
Registriert seit: Nov 2006
Beiträge: 29
cgdesign ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Das Problem ist wohl, dass ich ein LEFT JOIN auf 3 Tabellen mach und ich dann eben auch leere Werte zu meiner WHERE-Klausel zurückbekomme...
Mit Zitat antworten
  #7 (permalink)  
Alt 31-01-2007, 15:47
penizillin
 PHP Guru
Links : Onlinestatus : penizillin ist offline
Registriert seit: Feb 2004
Beiträge: 10.166
penizillin ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
... ob der nicht-leere Wert von row[9] größer-gleich ...
genau das hast du dir ausgedacht. was soll der "nicht-leere wert" von "" sein? und was ist der "leere wert" von "foo"? schau mal im manual, was empty() macht und baue deine abfrage schrittweise auf. erst prüfen, was leer ist. dann mit dem vergleichen, was nicht-leer ist.
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

PHP Marktplatz-Software
PHP Marktplatz-SoftwareEs hat sich viel getan! Die neue Version 7.5.9 unserer PHP Marktplatz-Software ebiz-trader steht ab sofort zur Verfügung.

28.10.2019 | Berni

Die RIGID-FLEX-Technologie
Die RIGID-FLEX-TechnologieDie sogenannte "Flexible Elektronik" , oftmals auch als "Flexible Schaltungen" bezeichnet, ist eine zeitgemäße Technologie zum Montieren von elektronischen Schaltungen.

06.12.2018 | Berni


 

Aktuelle PHP Scripte

SMT

Server Monitoring & Management Tool Das SMT wurde von einem Administrator für Administratoren entwickelt, es vereinfacht den Alltag in der klassischen Administration und Verwaltung. Mit dem SMT kannst Du alle Deine Server & Dienste verwalten und überwach

09.10.2020 palle_1977 | Kategorie: PHP
phplinX-Erotikportal 4 ansehen phplinX-Erotikportal 4

Erweiterbares Portal speziell für Erotik mit den Modulen Webkatalog, Bannermanagement und Kleinanzeigenmarkt. Sämtliche Module können über einen einzigen Adminbereich verwaltet werden.

18.06.2020 Cosinus14 | Kategorie: PHP/ Anzeigenmarkt
Erotik-Portal

Mit unsererem Erotik-Portal erhalten Sie ein komplettes Internetprojekt inklusive einer bedienerfreundlichem Administration sowie zahlreichen wichtigen Funktionen. Unser auf PHP und MySQL basierendes Script bietet Ihnen - und Ihren Besuchern - komfort

18.06.2020 ISD-Genthin | Kategorie: PHP/ Anzeigenmarkt
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 22:00 Uhr.