php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger

PHP Einsteiger PHP Problemlösungen für Spracheinsteiger
Archive: 2004, 2004/2, 2005, 2005/2, 2006, 2007, 2008, 2009, 2010,

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 08.01.2012, 17:42  
Erfahrener Benutzer
 
Benutzerbild von Sickone4
 
Registriert seit: 21.08.2011
Beiträge: 302
PHP-Kenntnisse:
Anfänger
Sickone4 befindet sich auf einem aufstrebenden Ast
Standard [Erledigt] Is null / is not null

hallo leute,

ich befasse mich gerade mit der optimierung meines counter scripts.

dabei möchte ich bei neueintrag alle zeile löschen lassen in der tabelle, die keine werte in einer gewissen spalte haben und welche größer sind als mein counterwert.

das ganze sah zu beginn so aus:

PHP-Code:
DELETE FROM test1 
WHERE counterType 
NOT IN 
('gesamt''monat_aktuell''tag'
   AND 
letzter_besuch '$alt' 
nun hab ich das verändert, weil mein konzept weitere werte in der spalte counterType schreibt die ich nicht gelöscht haben will. deren namen will ich aber nicht angeben sondern einfach die Spalte "counterType" abfragen ob inhalt drin ist ==> not null

nun hab ich mein statement verändert nach ->

PHP-Code:
DELETE FROM test1 
WHERE counterType 
IS NOT NULL
   
AND letzter_besuch '$alt' 
und was tut er? er löscht alles.....

diesen ausdruck hab ich mir von sql informationen entnommen, stimmt meine syntax nicht oder kann man den befehl "is null /is not null" nicht in der form mit einer weiteren anweisung verknüpfen?
__________________
irgendwann werde ich auch helfen können - vielleicht.
Sickone4 ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 08.01.2012, 17:48  
Erfahrener Benutzer
 
Benutzerbild von Dark Guardian
 
Registriert seit: 10.10.2009
Beiträge: 2.630
PHP-Kenntnisse:
Fortgeschritten
Dark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekannt
Standard

Sind in der Spalte wirklich NULL Werte hinterlegt oder Leere Strings?
__________________
"Alles im Universum funktioniert, wenn du nur weißt wie du es anwenden musst".
Dark Guardian ist offline   Mit Zitat antworten
Alt 08.01.2012, 17:55  
Erfahrener Benutzer
 
Benutzerbild von Sickone4
 
Registriert seit: 21.08.2011
Beiträge: 302
PHP-Kenntnisse:
Anfänger
Sickone4 befindet sich auf einem aufstrebenden Ast
Standard

die zelle ist entweder mit strings gefüllt doer leer.

ich kann mir unter NULL eigentlich nicht wirklich was vorstellen.

so ist das feld aufgebaut:

`counterType` varchar(20) collate latin1_german1_ci NOT NULL,
__________________
irgendwann werde ich auch helfen können - vielleicht.
Sickone4 ist offline   Mit Zitat antworten
Alt 08.01.2012, 18:00  
Erfahrener Benutzer
 
Registriert seit: 28.09.2008
Beiträge: 1.168
PHP-Kenntnisse:
Fortgeschritten
Koala befindet sich auf einem aufstrebenden Ast
Standard

NULL / NOT NULL bedeutet soviel wie gesetzt / nicht gesetzt.

Vor allem bei JOINs gibt es oft Ergebnismengen wo ein Wert einfach nicht
vorhanden ist (weil es z.B. keine Schnittmenge gibt).
Dann erhälst als Ergebnis NULL.

Du definierst ob eine Spalte NULL sein darf mit:
`spalte` .... NULL,
also genau anders rum als Du es gemacht hast.

Benutz phpmyadmin um solche Sachen zu prüfen/testen.
__________________
Eine if-else-Abfrage nimmt, ordentlich geschrieben eine Menge Platz weg. Platzsparend geht es mit einem ternären Operator.

Geändert von Koala (08.01.2012 um 18:11 Uhr).
Koala ist offline   Mit Zitat antworten
Alt 08.01.2012, 18:07  
Erfahrener Benutzer
 
Benutzerbild von Sickone4
 
Registriert seit: 21.08.2011
Beiträge: 302
PHP-Kenntnisse:
Anfänger
Sickone4 befindet sich auf einem aufstrebenden Ast
Standard

danke für deinen tip, so detailiert hab ichs mir gewünscht aber leider nicht gefunden!

sind denn dann pauschal alle meine tabellen die ich geschrieben habe "falsch" nur weil ich die felder nicht not null gesetzt hab?

das in phpmyadmin zu testen wäre klüger gewesen^^
__________________
irgendwann werde ich auch helfen können - vielleicht.
Sickone4 ist offline   Mit Zitat antworten
Alt 08.01.2012, 18:08  
Erfahrener Benutzer
 
Benutzerbild von Dark Guardian
 
Registriert seit: 10.10.2009
Beiträge: 2.630
PHP-Kenntnisse:
Fortgeschritten
Dark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekannt
Standard

http://dev.mysql.com/doc/refman/5.1/de/null-values.html

Ob das Erlauben von NULL Werten sinnvoll ist oder nicht musst du als Designer der Datenbank entscheiden. Das ist vom Anwendungsfall abhängig.
__________________
"Alles im Universum funktioniert, wenn du nur weißt wie du es anwenden musst".
Dark Guardian ist offline   Mit Zitat antworten
Alt 08.01.2012, 18:12  
Erfahrener Benutzer
 
Benutzerbild von Sickone4
 
Registriert seit: 21.08.2011
Beiträge: 302
PHP-Kenntnisse:
Anfänger
Sickone4 befindet sich auf einem aufstrebenden Ast
Standard

wie könnte ich denn einen leeren string abfragen?
__________________
irgendwann werde ich auch helfen können - vielleicht.
Sickone4 ist offline   Mit Zitat antworten
Alt 08.01.2012, 18:14  
Erfahrener Benutzer
 
Registriert seit: 28.09.2008
Beiträge: 1.168
PHP-Kenntnisse:
Fortgeschritten
Koala befindet sich auf einem aufstrebenden Ast
Standard

WHERE spalte = ''
__________________
Eine if-else-Abfrage nimmt, ordentlich geschrieben eine Menge Platz weg. Platzsparend geht es mit einem ternären Operator.
Koala ist offline   Mit Zitat antworten
Alt 08.01.2012, 18:37  
Erfahrener Benutzer
 
Benutzerbild von Sickone4
 
Registriert seit: 21.08.2011
Beiträge: 302
PHP-Kenntnisse:
Anfänger
Sickone4 befindet sich auf einem aufstrebenden Ast
Standard

super das funzt wunderbar!!
__________________
irgendwann werde ich auch helfen können - vielleicht.
Sickone4 ist offline   Mit Zitat antworten
Alt 08.01.2012, 18:59  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

Wird aber wiederum für echte NULL-Werte fehlschlagen. Weil ein Vergleich mit NULL kein BOOL sondern immer NULL ergibt. COALESCE(Spalte,'') wäre eine Variante.
__________________
--
One pixel is still too big. Please make it smaller. ASAP.

Initiative Mittelstand.
Die wichtigste Gestaltungsregel im Screendesign ist Pi mal Daumen des Arbeitgebers.
--
nikosch ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine 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
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
[Erledigt] MySQL Abfrage mit Inhalten eines Arrays _pho3nixx_ PHP Einsteiger 28 11.11.2011 11:58
[Erledigt] mysql_query() mit SQLDump princemichi PHP Einsteiger 4 07.03.2011 22:33
[Erledigt] MySQL + PHP script De Sena PHP Einsteiger 8 09.01.2011 13:50
Frage zu openGeoDb Joe Off-Topic Diskussionen 18 30.11.2010 15:54
Fehler bei CSV Import > MySQL fulltilt Datenbanken 8 20.08.2010 14:53
Tabelle nach Join sortieren xhiBseN Datenbanken 9 29.03.2010 10:52
SQL richtig umwandeln :( Sp1n PHP Tipps 2010 6 29.01.2010 11:35
[Erledigt] im sql kann ich tabelle nicht hinzufügen autofieber Datenbanken 7 01.03.2009 18:38
[Erledigt] Problem bei INSERTEN INTO RedDragon PHP Tipps 2008 37 18.07.2008 16:26
Normalisierung einer chaotischen Tabelle maeck Datenbanken 10 12.12.2006 18:17
[Erledigt] Bestell-Tabelle ok? PHP-Fortgeschrittene 4 28.11.2005 21:35
[Erledigt] Problem mit mySQL Datenbanken 7 27.09.2005 12:06
PHP-Fehlermeldung, weiss nicht mehr weiter PHP Tipps 2005-2 12 21.09.2005 12:56
Standart SQL Dump in PHP = Arbeits/Kostenersparnis ???????? PHP-Fortgeschrittene 7 12.06.2005 11:55
HILFE: Column count doesn't match value count at row 1 Datenbanken 17 12.06.2004 16:45

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
where is not null, is null php not, php is_not_null, not null

Alle Zeitangaben in WEZ +2. Es ist jetzt 18:43 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum