AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi DB - Komponente ohne GUI?
Thema durchsuchen
Ansicht
Themen-Optionen

DB - Komponente ohne GUI?

Ein Thema von Evilboyz · begonnen am 24. Feb 2003 · letzter Beitrag vom 24. Feb 2003
Antwort Antwort
Evilboyz

Registriert seit: 14. Jan 2003
78 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#1

DB - Komponente ohne GUI?

  Alt 24. Feb 2003, 10:24
Hallo allerseits!

Wenn ich in meinem Programm eine Komponente, beispielsweise die SQL Querry, verwenden will, platziere ich normalerweise einfach die entsprechende Komponente auf meinem Formular.
Nun möchte ich aber eine SQL Querry in einer Klasse verwenden, die keine grafische Oberfläche besitzt, wie binde ich die Komponente nun in diese Klasse ein???
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2
  Alt 24. Feb 2003, 10:41
Dynamisch im Code erzeugen:
Delphi-Quellcode:
var
  MyKompo : TKompo;
begin
  MyKompo := TKompo.Create;
  My Kompo._ _ _ := 'bla blub';
Und nicht vergessen mit Free wieder freigeben.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Evilboyz

Registriert seit: 14. Jan 2003
78 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#3
  Alt 24. Feb 2003, 13:00
Hallo Luckie,

vielen Dank für die Info, grundsätzlich sollte es so funktionieren! allerdings hat mein Code wohl noch Fehler, was ist in folgender Funktion falsch???
Ich bekomme einfach keinen Wert aus der Datenbank zurück!

Code:
function MyDBHandle.DBAccess(Input: String): String;
var
   MyQuery : TQuery;
begin
   try
      MyQuery := TQuery.Create(MyQuery);
      MyQuery.LoginPrompt := False;
      MyQuery.DatabaseName := 'Test';
      MyQuery.Active := False;
      MyQuery.SQL.Clear;
      MyQuery.SQL.Add('SELECT Info FROM Tab WHERE Number='+ QuotedStr (Input));
      MyQuery.Open;
      MyQuery.First;
      Result := MyQuery.FieldList.Values['Info'];
   except
      Result := '-1';
   end;
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#4
  Alt 24. Feb 2003, 13:08
Hai Evilboyz,

von welchem Typ ist denn das Feld Number in deiner Tabelle?

Wenn es nummerich ist musst Du die Abfrage ohne QuotedStr machen.

Achja, zum auslesen würde ich:
resulst := MyQuery.FieldByName ('info').AsString; nehmen. Ist aber geschmags sache ..
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#5
  Alt 24. Feb 2003, 13:11
Das sieht mit etwas seltsam aus:
MyQuery := TQuery.Create(MyQuery); Ich nehme mal an, dass der Parameter im Konstrukrur den Owner angibt. Wenn ja, ist das wohl ziemlich ungünstig, ein Objekt anzugeben, dass zu diesem Zeitpunkt noch nicht existiert, da es ja erst in diesem Moment erstellt wird. Schreib also besser folgendes:

MyQuery := TQuery.Create(nil);
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
Evilboyz

Registriert seit: 14. Jan 2003
78 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#6
  Alt 24. Feb 2003, 15:32
Zitat von Chewie:
Das sieht mit etwas seltsam aus:
MyQuery := TQuery.Create(MyQuery);
Ja, das sieht mir auch etwas seltsam aus ... danke für den Hinweis!
Zitat von Sharky:
Achja, zum auslesen würde ich:
resulst := MyQuery.FieldByName ('info').AsString; nehmen. Ist aber geschmags sache ..
Da stimme ich Dir mal zu, nachdem ich beides ausprobiert habe, bin ich absolut Deiner Meinung!
So und jetzt mal Danke an alle, die mir geholfen haben, es funktioniert endlich
  Mit Zitat antworten Zitat
Antwort Antwort


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:49 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