php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 04.02.2005, 12:38  
Gast
 
Beiträge: n/a
Standard Abfrage von Char-Feldern

Folgendes Problem:

VARCHAR-Felder kann man ohne Probleme mit

Code:
select * from tabelle where feld = 'Suchstring'
abfragen

Bei CHAR-Feldern ist die Angelenheit etwas komplizierter. Sämtliche Abfragen liefern mir kein Ergebnis (0 Treffer)

Ich habe nun rausgefunden dass bei Char-Feldern automatisch "Leer-Bits" angehängt werden um die definierte Länge des Feldes zu erreichen.

Wie muss ich nun nach dem Wert '00106' in einem CHAR(10)-Feld suchen ?

Code:
where feld = '00106' (kein Ergebnis)
Code:
where feld = '00106     ' (kein Ergebnis)
Ich bin schon soweit dass ich mit
Code:
where feld like '%00106'
das richtige Ergebnis erhalte. NUn ist aber anscheinend so, dass eine "normale" Abfrage und eine "Char" Abfrage nicht kombinierbar sind

Beispiel:
Ich suche den Datensatz der Feld1 = 72, Feld2 = 1 und Feld3(CHAR) = '00106' hat

Die Abfrage von Feld1+Feld2 funktioniert.
Die Abfrage von Feld3 funktioniert.
Die Abfrage von Feld1+Feld2+Feld3 funktioniert nicht.

Was mache ich falsch ?
  Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 04.02.2005, 12:49  
Moderator
 
Benutzerbild von robo47
 
Registriert seit: 03.09.2004
Beiträge: 11.792
PHP-Kenntnisse:
Fortgeschritten
robo47 kann auf vieles stolz seinrobo47 kann auf vieles stolz seinrobo47 kann auf vieles stolz seinrobo47 kann auf vieles stolz seinrobo47 kann auf vieles stolz seinrobo47 kann auf vieles stolz seinrobo47 kann auf vieles stolz seinrobo47 kann auf vieles stolz sein
Standard

falls LIKE funktioniert so z.b.

LIKE '00106%'
robo47 ist offline   Mit Zitat antworten
Alt 04.02.2005, 12:55  
Erfahrener Benutzer
 
Registriert seit: 21.12.2004
Beiträge: 5.232
PHP-Kenntnisse:
Fortgeschritten
mepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblick
mepeisen eine Nachricht über ICQ schicken mepeisen eine Nachricht über Skype™ schicken
Standard

Das sind keine "Leerbits" sondern Leerzeichen. Vgl.: http://dev.mysql.com/doc/mysql/en/char.html

Zitat:
The length of a CHAR column is fixed to the length that you declare when you create the table. The length can be any value from 0 to 255. (Before MySQL 3.23, the length of CHAR may be from 1 to 255.) When CHAR values are stored, they are right-padded with spaces to the specified length. When CHAR values are retrieved, trailing spaces are removed.
Wenn du also korrekt suchen wolltest, würde ich dir entweder empfehlen, die SQL- Funktion TRIM zu nutzen oder du füllst das in PHP bereits auf.

Also zwei Varianten:
Code:
SELECT feld2 FROM tabelle WHERE RTRIM(feld1) = 'Suchstring';

SELECT feld2 FROM tabelle WHERE feld1 = 'Suchstring           ';
P.S.: Verwende nicht SELECT *, gewäöhne dir das schnell wieder ab.
__________________
www.php-maven.org PHP und Maven vereint: Build/Deploy/Produktion/Konfiguration, Projekt Management, CI, PHPUnit, zahlreiche Frameworks
Twitter @ https://twitter.com/#!/mepeisen und Facebook @ http://t.co/DZnKSUih
mepeisen ist offline   Mit Zitat antworten
Alt 04.02.2005, 13:04  
Gast
 
Beiträge: n/a
Standard

So danke erstmal fürdie Antwort aber

1. kam ich von genau dieser Seite als ich entschieden habe Hilfe aufzusuchen

2. habe ich oben erwähnt dass ich genau dieses Schema verwendet habe, es aber nichts gebracht hat !

3. Select * war hier nur als Beispiel, bei Abfragen mit teilweise 50.000 Datensätzen wäre was wohl nicht so klug da hast du recht

4.
Code:
SELECT * FROM tabelle WHERE RTRIM(feld) = '00106'
funktionier NICHT: Es gibt aber 100%ig einen Datensatz mit diesem wert
  Mit Zitat antworten
Alt 04.02.2005, 13:08  
Erfahrener Benutzer
 
Registriert seit: 21.12.2004
Beiträge: 5.232
PHP-Kenntnisse:
Fortgeschritten
mepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblick
mepeisen eine Nachricht über ICQ schicken mepeisen eine Nachricht über Skype™ schicken
Standard

Dann stehen die schon falsch in der Datenbank. Die DB füllt immer mit Spaces am ENDE auf, nicht am Anfang. Wenn du also nur mit %00106 etwas findest, dann ist es nciht die "Schuld" von MySQL.
__________________
www.php-maven.org PHP und Maven vereint: Build/Deploy/Produktion/Konfiguration, Projekt Management, CI, PHPUnit, zahlreiche Frameworks
Twitter @ https://twitter.com/#!/mepeisen und Facebook @ http://t.co/DZnKSUih
mepeisen ist offline   Mit Zitat antworten
Alt 04.02.2005, 13:14  
Gast
 
Beiträge: n/a
Standard

OK das hat mich nämlich auch gewundert, da ich auch davon ausging das sie hinten angehängt werden.

Daurch löst sich nur leider mein Problem nicht ! Wie gesagt inzwischen geht es gar nicht mehr um das Char Feld ansich, daich mit "like '%00106' den gwünschten Datensatz erhalte. Das Probleme ist die Kombination mit anderen Bedingungen.


Nochmals das Beispiel von vorher:

Ich suche den Datensatz der Feld1 = 72, Feld2 = 1 und Feld3(CHAR) = '00106' hat

Die Abfrage von Feld1+Feld2 funktioniert.
Die Abfrage von Feld3 funktioniert.
Die Abfrage von Feld1+Feld2+Feld3 funktioniert nicht.
  Mit Zitat antworten
Alt 04.02.2005, 13:17  
Erfahrener Benutzer
 
Registriert seit: 21.12.2004
Beiträge: 5.232
PHP-Kenntnisse:
Fortgeschritten
mepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblick
mepeisen eine Nachricht über ICQ schicken mepeisen eine Nachricht über Skype™ schicken
Standard

Schalte den PC ein, vielleicht funktioniert es dann.

1. Bitte Selects posten
2. Bitte Fehler genau spezifizieren. Ein "funktioniert nicht" kannste gleich weglassen, weil das rein gar nichts aussagt.
__________________
www.php-maven.org PHP und Maven vereint: Build/Deploy/Produktion/Konfiguration, Projekt Management, CI, PHPUnit, zahlreiche Frameworks
Twitter @ https://twitter.com/#!/mepeisen und Facebook @ http://t.co/DZnKSUih
mepeisen ist offline   Mit Zitat antworten
Alt 04.02.2005, 13:24  
Gast
 
Beiträge: n/a
Standard

OK offensichtlich habe ich mich unklar ausgedrückt:

Ich hab eine Tabelle in der es unter anderem die Felder F1, F2, F3 gibt

F1 ... int
F2 ... int
F3 ... char(10)

Ich möchte den einen Datensatz der für F1 dern Wert X für F2 den Wert Y und für F3 den Wert Z besitzt, abfragen

Daher mein erster Versuch:

Code:
select * from tabelle where F1 = X and F2 = Y and F3 = 'Z'
Die Abfrage ist erfolgreich aber liefert 0 Datensätze

Nun habe ich mich vorgetastet

Code:
select * from tabelle where F1 = X and F2 = Y
Abfrage ist erfolgreich liefert aber leider viel zuviele Datensätze (nonaned)

Code:
select * from tabelle where F3 like '%Z'
Abfrage ist erfolgreich, aber leider wieder zu viele DS

Code:
select * from tabelle where F1 = X and F2= Y and F3 like '%Z'
Abfrage ist erfolgreich aber es werden 0 Datensätze gefunden

Wieso funktioniert es einzeln in Kombination aber nicht ??[/code]
  Mit Zitat antworten
Alt 04.02.2005, 13:55  
Erfahrener Benutzer
 
Registriert seit: 21.12.2004
Beiträge: 5.232
PHP-Kenntnisse:
Fortgeschritten
mepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblickmepeisen ist ein wunderbarer Anblick
mepeisen eine Nachricht über ICQ schicken mepeisen eine Nachricht über Skype™ schicken
Standard

Weil es vielleicht gar keine Schnittmenge gibt?
__________________
www.php-maven.org PHP und Maven vereint: Build/Deploy/Produktion/Konfiguration, Projekt Management, CI, PHPUnit, zahlreiche Frameworks
Twitter @ https://twitter.com/#!/mepeisen und Facebook @ http://t.co/DZnKSUih
mepeisen ist offline   Mit Zitat antworten
Alt 04.02.2005, 14:06  
Gast
 
Beiträge: n/a
Standard

Ich kann deine Überlegungen verstehen, aber glaub mir so einfach ist es nicht !

Selbst wenn ich mir einen Datensatz raussuche und dessen Werte als Suchkriterien verwende liefert die Abfrage 0 Datensätze !

Ist doch Strange ! Ich poste mal die Struktur der DB, vielleicht kann damit jemand was anfangen!

Code:
CREATE TABLE `online_bestellt` (
  `veranstnr` int(11) NOT NULL default '0',
  `bewerbnr` int(11) NOT NULL default '0',
  `startnr` char(10) NOT NULL default '',
  `kennbuchst` char(1) NOT NULL default '',
  `anzahl` int(11) default NULL,
  `preis` double(6,2) default NULL,
  `lieferstatus` int(11) default NULL,
  `rechnungsnr` char(20) default NULL,
  `versanddatum` char(10) default NULL,
  PRIMARY KEY  (`veranstnr`,`bewerbnr`,`startnr`,`kennbuchst`)
) TYPE=MyISAM;
wobei gilt:

veranstnr = F1
bewerbnr = F2
startnr = F3
  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
Abfrage von einer Abfrage Datenbanken 5 27.01.2011 23:31
mysql abfrage in Schleife havok PHP Tipps 2006 6 09.05.2006 08:39
Abfrage: sortieren mit mehreren Feldern, ASC und DESC php_frage Datenbanken 3 29.04.2006 20:42
zählen in mehreren Feldern jens76 Datenbanken 4 01.11.2005 13:39
abfrage begrenzen Cyrus Datenbanken 4 26.10.2005 11:29
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
[Erledigt] IF() abfrage in variable packen PHP Tipps 2005 14 01.04.2005 17:23
[Erledigt] SQL Abfrage funzt nicht Datenbanken 2 04.02.2005 11:09
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
2 Tabellen 1 Abfrage nilsfeld Datenbanken 6 11.08.2004 11:18
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
php char, char abfragen, java char abfragen, char php, java char abfrage, sql abfrage char, sql char abfrage, sql character abfragen, mysql abfrage char, char abfrage java, char in php, char abfragen java, formel1 startnummer 34 wiki, leerzeichen abfrage java, char abfrage, java auf char abfragen, char abfragen#, java abfrage inhalt char feld, char feld java, char sql abfrage

Alle Zeitangaben in WEZ +2. Es ist jetzt 04:53 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

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.