AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebeird]
Thema durchsuchen
Ansicht
Themen-Optionen

Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebeird]

Ein Thema von Ati · begonnen am 27. Nov 2005 · letzter Beitrag vom 30. Nov 2005
Antwort Antwort
Seite 1 von 4  1 23     Letzte »    
Ati

Registriert seit: 16. Okt 2003
Ort: Gelsenkirchen
406 Beiträge
 
Delphi 3 Professional
 
#1

Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebeird]

  Alt 27. Nov 2005, 16:27
Datenbank: Firebirf • Version: 1.5 • Zugriff über: Zeos
Ich möchte eine kleine Tabelle mit Daten füllen können bzw. anzeigen lassen können.
Tabellenstruktur: ID (PK,Smallint);Nummer (Integer); Name (varchar (45))
Eigentlich ja nichts wildes. Zugriff erfolgt über Zeos. Da fällt mir ein das laut diesem Tutorial eine Komponente "DataSource" vorhanden sein sollte... diese habe ich aber nicht. Habe ich bei der Installation der Zeos-Komponenten noch was vergessen???
Die Verbindung zur DB wird wie folgt aufgebaut:
Delphi-Quellcode:
 procedure TForm1.FormShow(Sender: TObject);
begin
dbMain.Host:='localhost';
dbMain.Login:='user';
dbMain.Password:='guest';
dbMain.Database:='c:\Firebird\Firebird_1_5\eigene\test.fdb';
dbMain.Connected:=true;
trMain.Database:=dbMain;
end;

Die Dateneingabe wie folgt:
Delphi-Quellcode:
procedure TForm1.btnAddClick(Sender: TObject);
begin
 qrMain.SQL.Text:='INSERT INTO vim '+
                    '(nummer, name)'+
                    ' VALUES '+
                    '('''+ednummer.Text+''', '''+edName.Text+''');';
qrMain.ExecSql;

 
end;
Hier habe ich aufgrund des Feldes ID eine Fehlermeldung. Plan war es dieses Feld automatisch zu füllen per Autozähler/Generator. Wahrscheinlich habe ich hier in der DB was falsch gemacht. Wie legt man also bitte ein Feld ID mit automatischer "Füllung" an?
Ich weiß das ich nichts weiß

Sokrates
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 27. Nov 2005, 16:50
Zitat von Ati:
...eine Komponente "DataSource" vorhanden sein sollte... diese habe ich aber nicht. ...
Hai Ati,

Delphi-Referenz durchsuchenTDataSource ist nicht Bestandteil der ZeosLib sondern deines Delphi prof. Du findest die Komponente unter der Registerkarte Datenzugriff. Mit dieser Verbindest Du dein TDataSet (Table oder Query) und dann zum Beispiel ein DBGrid oder DBEdit mit der DataSource.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Ati

Registriert seit: 16. Okt 2003
Ort: Gelsenkirchen
406 Beiträge
 
Delphi 3 Professional
 
#3

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 27. Nov 2005, 17:33
UPS. Sorry das hatte ich im Tut anders verstanden. Naja so wie ich gelesen habe ist das mit dem Autowert bei Firebird etwas komplizierter, deswegen werde ich mich später darum kümmern. Ohne dem ID-Feld gehen meine Eingaben ja, nur den Abruf (egal ob in einem Textfeld oder in einem Listview) kriege ich nicht hin!! Hier mal der letzte Code.
Delphi-Quellcode:
procedure TForm1.btnanzeigeClick(Sender: TObject);
var ListItem: TListItem;
begin
  qrMain.SQL.Text:='Select * from vim; ';
  qrMain.Open;
  while not qrMain.EOF do
  begin
  ListItem:= Listview1.Items.Add;
  {ListItem.Caption:= qrMain.fielbyname('id').asString;}
  listItem.SubItems.Add(qrMain.FieldbyName('nummer').asString);
  qrMain.Next;
  end;
end;
Wenn ich den Button zum Abrufen der Daten drücke kommt eine Fehlermeldung in der Unit ZIBSqlQuery mit der Zeile:
FieldDescKey := FindPrimaryKey;
Ich weiß das ich nichts weiß

Sokrates
  Mit Zitat antworten Zitat
Ati

Registriert seit: 16. Okt 2003
Ort: Gelsenkirchen
406 Beiträge
 
Delphi 3 Professional
 
#4

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 28. Nov 2005, 16:03
Ich verzweifele so langsam. Ich habe jetzt mein altes Projekt gelöscht und ganz von vorne angefangen. Ich kann Daten eingeben und auch löschen. Nur den Tabelleninhalt kann ich nicht anzeigen lassen. Wäre bitte einer mal so nett und könnte mir sagen wo ich den Fehler mache.
Delphi-Quellcode:
procedure TForm1.AbrufClick(Sender: TObject);
{var ListItem:TlistItem;}
begin
qrMain.Sql.Clear;
qrMain.Sql.Text:='SELECT * FROM vim;';
qrMain.Open;
while not qrMain.EOF do
begin
ListView1.Items.Add(qrMain.fieldbyname('nummer').asString);
ListView1.Items.Add(qrMain.fieldbyname('name').asString);
qrMain.Next
end;
end;
Ich weiß das ich nichts weiß

Sokrates
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#5

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 28. Nov 2005, 16:05
Hai Ati,

hast Du denn entsprechende Spalten in deinem ListView erzeugt?
P.S.: Der code müsste aber doch so aussehen wie in deinem Posting von Gestern 17:33 oder?
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Ati

Registriert seit: 16. Okt 2003
Ort: Gelsenkirchen
406 Beiträge
 
Delphi 3 Professional
 
#6

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 28. Nov 2005, 16:13
Ich komme ja gar nicht soweit. Bei der CodezeileListView1.Items.Add(qrMain.fieldbyname('nummer').asString); , meckert er "zuviele Parameter an. Bei dem Post von gestern hatte ich ja noch eine ID dabei, die habe ich aber erstmal rausgeschmiessen, da das mit den Autowerten bei Firebird wohl ein wenig komplizierter ist. Mir geht es erstmal darum irgendwie (egal wie) mir Datensätze aus der Tabelle anzeigen zu lassen. Getreu dem Mottoolitik der kleinen Schritte!!

Ati
Ich weiß das ich nichts weiß

Sokrates
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#7

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 28. Nov 2005, 16:42
Zitat von Ati:
Ich komme ja gar nicht soweit. ...


Du hast am Sonntag ja auch einen anderen Code gehabt
Code:
procedure TForm1.btnanzeigeClick(Sender: TObject);
var
  [color=red]ListItem: TListItem;[/color]
begin
  qrMain.SQL.Text:='Select * from vim; ';
  qrMain.Open;
  while not qrMain.EOF do
  begin
    [color=red][b]ListItem:= Listview1.Items.Add;[/b][/color]
    ListItem.Caption:= qrMain.fielbyname('id').asString;
    listItem.SubItems.Add(qrMain.FieldbyName('nummer').asString);
    qrMain.Next;
  end;
end;
TListView.Items.Add ist eine Funktion die ein "neues" TListItem zurück gibt.

Vergleiche das mal mit deinen Code von heute.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Ati

Registriert seit: 16. Okt 2003
Ort: Gelsenkirchen
406 Beiträge
 
Delphi 3 Professional
 
#8

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 28. Nov 2005, 17:05
Also Hasenzahn,

mein alter Code beinhaltete ja noch eine ID welche per Autowert mit jedem neuen Datensatz höher gezählt werden sollt. Jedoch geht das so einfach nicht bei Firebird (hatte da auch schon ein Thread zu gefunden). Also lasse ich das erstmal. Ich habe jetzt nur ein Tabelle, wo ich die Vim-Nummer und den dazugehörigen Namen eintrage. Diese Daten möchte ich mir jetzt mal irgendwie anzeigen lassen. Mir ist es egal ob in einem ListView, Memofeld oder in einem Editfeld. Also vergiss das erstmal mit meinem alten Code bitte. Ich will mich da jetzt langsam voran tasten.

Ati
Ich weiß das ich nichts weiß

Sokrates
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#9

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 28. Nov 2005, 17:10
Zitat von Ati:
Also Hasenzahn,
süüüsssss

Okay.
Delphi-Quellcode:
procedure TForm1.AbrufClick(Sender: TObject);
var
  ListItem:TlistItem;
begin
  qrMain.Sql.Clear;
  qrMain.Sql.Text:='SELECT * FROM vim;';
  qrMain.Open;
  // Bis hier hast Du eine SQL-Abfrage gemacht welche Dir alle Datensätze der Tabelle vim liefert
  
  while not qrMain.EOF do // Solange Du nicht am ende der Tabelle bist
  begin
    ListItem := ListView1.Items.Add; // Erzeuge einen neuen Eintrag im ListView
    ListItem.Caption := qrMain.fieldbyname('nummer').asString; // Beschreiftung für Spalte-1
    ListItem.SubItems.Add(qrMain.fieldbyname('name').asString); // Beschriftung für Spalte-2 (Subitem 1)
    qrMain.Next // Zum nächsten Datensatz
  end;
end;
Du musst dein ListView jetzt auf ViewStyle := vsReport stellen und zwei Spalten erzeugen (mit der rechten Maustaste draufklicken und den SpaltenEditor auswählen.

Dann sollte es gehen.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Ati

Registriert seit: 16. Okt 2003
Ort: Gelsenkirchen
406 Beiträge
 
Delphi 3 Professional
 
#10

Re: Eingabe und Anzeigen von Daten [Delphi3 Pro+Zeos+Firebei

  Alt 28. Nov 2005, 17:23
Ich glaube das hatte ich in meinen ca. 15.000 Versuchen schon. Fehlermeldung siehe Anhang!!!
Miniaturansicht angehängter Grafiken
dbfehler2_187.jpg  
Ich weiß das ich nichts weiß

Sokrates
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 4  1 23     Letzte »    


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 06:01 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz