AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Probleme mit Select Statement
Thema durchsuchen
Ansicht
Themen-Optionen

Probleme mit Select Statement

Ein Thema von Kedariodakon · begonnen am 23. Jan 2006 · letzter Beitrag vom 23. Jan 2006
 
Benutzerbild von Kedariodakon
Kedariodakon

Registriert seit: 10. Sep 2004
Ort: Mönchengladbach
833 Beiträge
 
Delphi 7 Enterprise
 
#1

Probleme mit Select Statement

  Alt 23. Jan 2006, 14:37
Datenbank: MS-SQL • Zugriff über: SQL Query Analyzer
Meine Tabelle
SQL-Code:
/* Die Tabelle - swgResourceClass */
Create Table swgResourceClass
(
  Id Int Not Null Primary Key Clustered,
  ParentID Int Foreign Key References swgResourceClass( Id ) Null,
  SwgCraftId VarChar( 30 ) Not Null,
  Name VarChar( 100 ) Not Null
)
Meine Testdaten in der Tabelle
SQL-Code:
/* BasisKlassen */
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 1, Null, 'ino', 'Inorganic' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 2, Null, 'org', 'Organic'   )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 3, Null, 'egy', 'Energy'    )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 4, Null, 'ast', 'Space'     )

/* Children Klassen von Inorganic */
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 5, 1, 'gem', 'Gemstone' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 6, 1, 'lgo', 'Low-Grade Ore' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 7, 1, 'mtl', 'Metal' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 8, 1, 'rad', 'Radioactive' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 9, 1, 'spc', 'Solid Petrochem Fuel' )

/* Children Klassen von Gemstone */
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 10, 5, 'cry', 'Crystalline Gemstone' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 11, 5, 'amo', 'Amorphous Gemstone' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 12, 5, 'lgem', 'Low Quality Gemstone' )
Insert Into swgResourceClass ( Id, ParentID, SwgCraftId, Name ) Values ( 13, 5, 'ugt', 'Unknown Gem Type' )
Alle Daten vom Select
Code:
/* Daten (Select * From swgResourceClass) */
/*
Id PaentId SwgCraftId Name
1   NULL    'ino'      'Inorganic'
2   NULL    'org'      'Organic'
3   NULL    'egy'      'Energy'
4   NULL    'ast'      'Space'
5   1        'gem'      'Gemstone'
6   1        'lgo'      'Low-Grade Ore'
7   1        'mtl'      'Metal'
8   1        'rad'      'Radioactive'
9   1        'spc'      'Solid Petrochem Fuel'
10  5        'cry'      'Crystalline Gemstone'
11  5        'amo'      'Amorphous Gemstone'
12  5        'lgem'     'Low Quality Gemstone'
13  5        'ugt'      'Unknown Gem Type'
*/
Info: Die Klassen können unterschiedlich tief sein...

Nun ich habe folgendes Problemchen, ich möchte alle Klassen und Childrens einer Klasse ausgeben...
Das heißt ich versuche im oben genanntem Beispiel alle Klassen auszugeben, die zur Klasse 'Inorganic' gehören...

Das heißt:
- Der Datensatz mit der (Id = 1)
- Die Datensätze mit der (ParentId = 1)
Und nun zum Problem:
- Die Datensätze mit der (ParentId = ( Id von Allen mit der ParentId = 1 ))
- Die Datensätze mit der (ParentId = ( ParentId = ( Id von Allen mit der ParentId = 1 )))
... (usw) ...

Mit den obrigen Daten sollte das Result so ausschaun (Name = 'Inorganic'):
Code:
/*
Id PaentId SwgCraftId Name
1   NULL    'ino'      'Inorganic'
5   1        'gem'      'Gemstone'
6   1        'lgo'      'Low-Grade Ore'
7   1        'mtl'      'Metal'
8   1        'rad'      'Radioactive'
9   1        'spc'      'Solid Petrochem Fuel'
10  5        'cry'      'Crystalline Gemstone'
11  5        'amo'      'Amorphous Gemstone'
12  5        'lgem'     'Low Quality Gemstone'
13  5        'ugt'      'Unknown Gem Type'
*/
Nun, ich hab keine Ahnung wie ich so ein verschachteltes Select mache, falls sowas überhaupt geht...
Hat da jemand vielleicht eine Idee dazu?

Bye Keda
Christian
  Mit Zitat antworten Zitat
 


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 aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:19 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz