Delphi-PRAXiS
Seite 1 von 4  1 23     Letzte »    

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Liste in ein DBGrid schreiben (https://www.delphipraxis.net/106364-liste-ein-dbgrid-schreiben.html)

andy21 9. Jan 2008 18:43

Datenbank: Mybase • Zugriff über: DbGrid

Liste in ein DBGrid schreiben
 
Hallo,

ich benutze Mybase und habe bei mir im Programm einmal ClientDataSet, DataSource und DBGrid.

Speichern und laden funktioniert einwandfrei. Manuell (im DBGrid) kann ich ja auch schreiben. Ich habe jedoch einen Extra-Liste, die ich auch so in einzelne Strings teilen kann, jedoch will ich diese Daten in das DBGrid schreiben um es dann ganz normal zu speichern. Ich habe jedoch überhaupt keine Ahnung wie ich die einzelnen Felder ansteuern kann. Es gibt solche Eigenschaften Fields, wenn ich jedoch folgendes Schreibe

dbgrid1.fields[2]:='hallo';

dann erscheint als Fehlermeldung: [Fehler] Unit1.pas(49): Einer Nur-Lesen Eigenschaft kann kein Wert zugewiesen werden.

Wie kann ich da jetzt etwas in das DB-Grid schreiben, so dass ich auf einen Knopf drücke und es sich dann füllt.


Danke im Voraus. :)

DeddyH 9. Jan 2008 18:50

Re: Liste in ein DBGrid schreiben
 
Ich editiere zwar nie in DBGrids, aber geht es evtl. so?
Delphi-Quellcode:
dbgrid1.DataSource.DataSet.fields[2]:='hallo';
[edit] Das setzt aber voraus, dass das DataSet zuvor in den Edit-Modus versetzt wurde. [/edit]

s-off 9. Jan 2008 18:55

Re: Liste in ein DBGrid schreiben
 
Ich glaube, hier liegt eher ein grundlegendes Verständnisproblem zum Umgang mit Datenbanken vor :zwinker:

Schau Dir einfach mal entsprechende Tutorials dazu an.

andy21 9. Jan 2008 18:59

Re: Liste in ein DBGrid schreiben
 
Zitat:

Ich editiere zwar nie in DBGrids, aber geht es evtl. so?
Delphi-Quellcode: markieren
dbgrid1.DataSource.DataSet.fields[2]:='hallo';


[edit] Das setzt aber voraus, dass das DataSet zuvor in den Edit-Modus versetzt wurde. [/edit]

Wenn ich diese Zeile nehme erscheint folgende Fehlermeldung: [Fehler] Unit1.pas(49): Inkompatible Typen: 'TField' und 'String'

Und was ist mit dem letzten Satz gemeint? :?:


Zitat:

Ich glaube, hier liegt eher ein grundlegendes Verständnisproblem zum Umgang mit Datenbanken vor Zwinkern

Schau Dir einfach mal entsprechende Tutorials dazu an.
Von daher habe ich das mit dem Mybase. Oder was meinst du da genau? ^^

DeddyH 9. Jan 2008 19:00

Re: Liste in ein DBGrid schreiben
 
Sorry, mein Versäumnis.
Delphi-Quellcode:
dbgrid1.DataSource.DataSet.fields[2].AsString:='hallo';
Achja, schau auch mal hier (die weiterführenden Links bitte nicht ignorieren ;) )

andy21 9. Jan 2008 19:08

Re: Liste in ein DBGrid schreiben
 
Zitat:

Zitat von DeddyH
Sorry, mein Versäumnis.
Delphi-Quellcode:
dbgrid1.DataSource.DataSet.fields[2].AsString:='hallo';
Achja, schau auch mal hier (die weiterführenden Links bitte nicht ignorieren ;) )

Da erscheint jetzt folgende Fehlermeldung: "Im Projekt project1.exe ist eine Exception der Klasse EDataBaseError aufgetreten. Meldung:'ClientDataSet1:Datenmenge weder im Editier- noch im Einfügemodus'. Prozess wurde angehalten. Mit einzelne Anweisung oder Start Fortsetzen."

Anbei wie kann man eigentlich die Zeilenanzahl des DBGrids erhöhen? Ich kann nur die Spalten einstellen, aber "Rows" finde ich nirgendwo.

DeddyH 9. Jan 2008 19:14

Re: Liste in ein DBGrid schreiben
 
Ein DBGrid dient lediglich der Darstellung einer Ergebnismenge, die ihm zugewiesen wurde. Die Schnittstelle zwischen dieser Ergebnismenge (z.B. einer TTable oder einer TQuery etc.) bildet eine DataSource. Wenn sich nun also die Darstellung ändern soll, musst Du die zugrundeliegenden Daten ändern.

andy21 9. Jan 2008 19:18

Re: Liste in ein DBGrid schreiben
 
Ähm, ich kann doch die Daten durch eintippen in das DBGrid ändern, also wenn ich etwas in das DBGrid schreibe und es dann speichere sind die Daten geändert, oder? Oder wie war das jetzt gemeint? :?:

DeddyH 9. Jan 2008 19:21

Re: Liste in ein DBGrid schreiben
 
Das war nur als Veranschaulichung der Zusammenhänge gemeint. Aber wie die zitierte Fehlermeldung bereits sagt (und ich in meiner ersten Antwort schon angemerkt hatte) musst Du erst in den Editiermodus wechseln. Versuch es mal so:
Delphi-Quellcode:
dbgrid1.DataSource.DataSet.Edit; //in den Editiermodus wechseln
dbgrid1.DataSource.DataSet.fields[2].AsString:='hallo'; //Daten ändern
dbgrid1.DataSource.DataSet.Post; //Änderungen speichern

andy21 9. Jan 2008 19:24

Re: Liste in ein DBGrid schreiben
 
Ah, es klappt. Vielen Dank.
Doch eine Frage bleibt noch. Wie bekomme ich mehr Zeilen hin?


Alle Zeitangaben in WEZ +1. Es ist jetzt 20:41 Uhr.
Seite 1 von 4  1 23     Letzte »    

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