php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 15.12.2011, 17:34  
Neuer Benutzer
 
Registriert seit: 11.12.2011
Beiträge: 20
PHP-Kenntnisse:
Anfänger
Cholec befindet sich auf einem aufstrebenden Ast
Standard Verschachtelte Entitys auslesen

Hallo ich habe ein kleine Problem, da ich die Syntax noch nich so kenne:

Ich habe eine Datenbank mit verschiedenen Vögeln, die Systematik ist wie folgt:

Es gibt n Ordnungen
jede Ordnung besitzt n Familien, jede Familie genau eine Ordnung
jede Familie bestitzt n Gattungen, jede Gattung genau eine Familie
jede Gattung besitzt n Arten, jede Art genau eine Gattung.

nun versuche ich z.b. für eine besstimmte Ordnung oder Familie ALLE Arten ausgeben zu lassen. Die Gattungen machen kein Problem, da ich einfach durch die Artenliste gehe und über eine while Schleife alle Arten ausgebe.

Aber verschachtelt funktioniert das nicht mehr und wird auch ziemlich rechenaufwändig. Gibt es eine möglichkeit das mit VIEW zu lösen?

PHP-Code:
// einfache ausgabe der Arten in einer Gattung
function writeTable()    {

    while (
$row mysql_fetch_array($searchresult))    {
                    
                
$currentBirdID $row["VogelID"];
                
$currentBird mysql_query("SELECT LATEINISCHER_NAME FROM VOGELART where VOGELID LIKE '$currentBirdID'");
                
$currentGenus mysql_query("SELECT LATEINISCHER_GATTUNGSNAME FROM VOGELART where VOGELID LIKE '$currentBirdID'");        }

Das war bisher mein Ansatz für alle Arten einer Familie. Die searchresult-query wird dann der writeTable() function übergebe und so werden die Gattungen durchgegangen und alle Arten ausgegeben, theoretisch... funktioniert aber so nicht und ist vielleicht auch nicht die beste Lösung (???).

PHP-Code:
if (isset($_GET["family"])) {
        
$searchedFamily $_GET["family"];
        
$allGenus mysql_query("SELECT LATEINISCHER_GATTUNGSNAME FROM GATTUNG where LATEINISCHER_FAMILIENNAME LIKE '$searchedFamily'");
        while (
$row mysql_fetch_array($allGenus))    {
        
$currentGenus $row["LATEINISCHER_GATTUNGSNAME"];
        
$searchresult mysql_query("SELECT VogelID FROM VOGELART where LATEINISCHER_GATTUNGSNAME LIKE '$currentGenus'");
        
writeTable();
        }

Cholec ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 15.12.2011, 18:52  
Erfahrener Benutzer
 
Registriert seit: 21.12.2009
Beiträge: 415
PHP-Kenntnisse:
Fortgeschritten
G.Schuster ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Freunde dich mit JOINs an und vor allem: verzichte auf LIKE, das an den Stellen so oder so keinen Sinn macht, zumal die zugehörigen Platzhalter (% bzw. _) fehlen.
Ach so, mysql_real_escape_string() solltest du dir auch ansehen.
__________________
actra.development - Schwabstr. 2 - 70825 Münchingen
www.actra.de/velopment/ - eMail: php.de@actra.de
Zend Certified Engineer for PHP5
G.Schuster ist offline   Mit Zitat antworten
Alt 15.12.2011, 18:52  
Erfahrener Benutzer
 
Registriert seit: 01.06.2011
Beiträge: 389
PHP-Kenntnisse:
Anfänger
achtelpetit befindet sich auf einem aufstrebenden Ast
Standard

Welche Tabellen hast Du denn?
achtelpetit ist offline   Mit Zitat antworten
Alt 15.12.2011, 22:24  
Neuer Benutzer
 
Registriert seit: 11.12.2011
Beiträge: 20
PHP-Kenntnisse:
Anfänger
Cholec befindet sich auf einem aufstrebenden Ast
Standard

Es gibt unter anderem die Tabellen:
Art
[Artname][Gattungsname]

Gattung
[Gattungsname][Familienname]

Familie
[Familienname][Ordnungsname]

Ordnung
[Ordnungsname]

also jeweils mit Eintrag auf die nächsthöhere Instanz.

Sollte ich in dem Fall lieber IS statt LIKE benutzen?
Wenn ich mit % arbeite MUSS dann LIKE hin?

werd mir die methoden mal ansehen
Cholec ist offline   Mit Zitat antworten
Alt 15.12.2011, 22:29  
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

Zuallererst solltest Du die Tabelle mal normalisieren. Die Namen als foreign key haben darin nichts zu suchen.
Normalisierung
__________________
--
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
Alt 15.12.2011, 22:30  
Erfahrener Benutzer
 
Registriert seit: 21.12.2009
Beiträge: 415
PHP-Kenntnisse:
Fortgeschritten
G.Schuster ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Du solltest vor allem mit numerischen IDs arbeiten statt mit Text-Values.
Und vor allem musst du den Unterschied zwischen einem "is" und "like" verstehen.
Wenn ich einen exakten Wert will sage ich nicht "gib mir, was so ähnlich aussieht" (like) und andersrum.

Aber ich denke, das führt im Moment zu weit, denn mir scheint, dass dir noch die Grundlagen im DB-Design fehlen - lies dich da am besten mal tiefer ein.
__________________
actra.development - Schwabstr. 2 - 70825 Münchingen
www.actra.de/velopment/ - eMail: php.de@actra.de
Zend Certified Engineer for PHP5
G.Schuster ist offline   Mit Zitat antworten
Alt 15.12.2011, 23:57  
Erfahrener Benutzer
 
Registriert seit: 01.06.2011
Beiträge: 389
PHP-Kenntnisse:
Anfänger
achtelpetit befindet sich auf einem aufstrebenden Ast
Standard

In absteigender Reihenfolge hast Du also:
Ordnung - Familie - Gattung - Art
Dann sollten Deine Tabellen so aussehen:

Tabelle Ordnung
Ordnung-Id | Ordnung

Tabelle Familie
Familie-Id | Ordnung-Id | Familie

Tabelle Gattung
Gattung-Id | Familie-Id | Gattung

Tabelle Art
Art-Id | Gattung-Id | Art

So kannst Du Dich wunderbar rauf- unter runterhangeln und alles ist wunderbar normalisiert. Wie schon gesagt wurde, solltest Du unbedingt mit numerischen Ids arbeiten, am Einfachsten mit Autoincrement. Das hat erstens den Vorteil, dass Du einen eventuellen Schreibfehler später korrigieren kannst, ohne die Schlüssel anzufassen und außerdem sind Zahlen für den Computer schneller zu verarbeiten.
achtelpetit ist offline   Mit Zitat antworten
Alt 16.12.2011, 00:02  
Neuer Benutzer
 
Registriert seit: 11.12.2011
Beiträge: 20
PHP-Kenntnisse:
Anfänger
Cholec befindet sich auf einem aufstrebenden Ast
Standard

... ist erledigt. Habs direkt im Datenmodell geändert und neu generiert. Gib es noch Dinge die ich beachten sollte?
Cholec ist offline   Mit Zitat antworten
Alt 16.12.2011, 12:07  
Erfahrener Benutzer
 
Registriert seit: 01.06.2011
Beiträge: 389
PHP-Kenntnisse:
Anfänger
achtelpetit befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Gib es noch Dinge die ich beachten sollte?
Vor allem: nix verkehrt machen.
Aber im Ernst, welche Antwort erwartest Du? Ich weiß doch nicht, was Du überhaupt machen willst.
achtelpetit ist offline   Mit Zitat antworten
Alt 17.12.2011, 04:02  
Neuer Benutzer
 
Registriert seit: 11.12.2011
Beiträge: 20
PHP-Kenntnisse:
Anfänger
Cholec befindet sich auf einem aufstrebenden Ast
Standard

Hallo,
ja das ist nicht so einfach zu erklären.
Hab nochmal was rausgesucht. ich weiß ungefähr wie ein Join funktiert, aber ich weiß nicht genau wie ich die Syntax anwende.

ich habe die Tabellen

Vogelart mit Vogel_ID und Gattungs_ID
Gattung mit Gattungs_ID und Familien_ID
Familie mit Familien_ID

ich möchte jetzt:
ALLE Vogelarten, also alle Vogel_IDs ausgeben, die eine bestimmte Familien_ID haben.
Die Familien_ID wird ja über die Gattungs_ID definiert, deswegen weiß ich nicht in welcher Form ich da syntaktisch rankomme.
Ein ganz einfaches Grundgerüst zu DIESEM Beispiel würde mir sehr helfen.

lg und gute Nacht
Cholec 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 BINARY Blob-Feld auslesen ejay Datenbanken 4 26.04.2011 09:49
Cookie setzen und auslesen Rutor PHP Einsteiger 8 28.01.2011 08:55
[Erledigt] Verschachtelte Liste aus Datenbank auslesen ArcticMonkey Datenbanken 6 28.11.2010 21:12
[Erledigt] preparedStatement auslesen funktioniert nicht ?! Raidri PHP Tipps 2009 11 02.11.2009 09:21
Verschachtelte Kategorie IDs mit variabler Tiefe auslesen Shen PHP Tipps 2009 1 27.08.2009 09:23
[Erledigt] Anzahl der Zeilen auslesen ( MySQL ) errox Datenbanken 13 18.02.2009 16:07
[Erledigt] variable Postvariablen auslesen carsten PHP Tipps 2008 2 30.10.2008 16:20
Ordner auslesen und während des auslesen sortieren Dooki PHP Tipps 2008 6 14.05.2008 17:50
Vom Browser verschickte Daten auslesen und anzeigen? andy32 PHP Tipps 2008 3 22.08.2007 18:33
[Erledigt] Datenbank auslesen mit register_globals off PHP Tipps 2007 14 03.01.2007 17:12
[Erledigt] gelöst: Tabelle auslesen -> Gleiche Einträge nur 1 Mal Datenbanken 3 31.03.2006 01:44
Daten eintragen und auslesen Rettungsdackel Datenbanken 0 14.09.2005 16:29
auslesen und nochmals auslesen?! $$$ ThiKool $$$ PHP Tipps 2005 23 10.03.2005 19:43
[Erledigt] Daten von anderer Homepage auslesen PHP Tipps 2004-2 5 02.12.2004 18:49


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