AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Inkompatibel TStrings und String
Thema durchsuchen
Ansicht
Themen-Optionen

Inkompatibel TStrings und String

Ein Thema von Iso · begonnen am 3. Jun 2005 · letzter Beitrag vom 3. Jun 2005
Antwort Antwort
Iso

Registriert seit: 3. Jun 2005
4 Beiträge
 
Delphi 7 Enterprise
 
#1

Inkompatibel TStrings und String

  Alt 3. Jun 2005, 16:01
Datenbank: MYSQL • Version: 4 • Zugriff über: MyDac
Hi Leute!
Programmiere erst seit ca. 2 Wochen mit Delphi und wollte jetzt versuchen, mich mit einer MYSQL-Datenbank zu verbinden.
Ich benutze zum verbinden und arbeiten mit der Datenbank "MyDac".

In meiner Form hab ich die 3 Komponenten aus der MYSQL-IDE MyConnection, MyQuery und MyCommand,
verbindung zum Server steht auch,
jetzt möchte ich in meine Tabelle einen neuen Kunden einfügen und habe dies folgendermaßen versucht:

Delphi-Quellcode:
procedure Tfrmadmin.cmdneubenClick(Sender: TObject);
begin

name := txtneuname.text;
passwort := txtneupass.text;
guthaben := txtneugut.text;
zins := txtneuzins.text;
einfuegen := 'INSERT INTO kunden VALUES(NULL,' + name + ', ' + passwort + ', ' + guthaben +', ' + zins + ')';
mycommand.SQL := einfuegen;
mycommand.Execute;

end;
Doch leider hat er einen Fehler, nämlich in der Zeile mycommand.SQL := einfuegen
Er meint "Inkompatible Typen: 'TStrings' und 'String'.
Die Variable "einfuegen" habe ich als string deklariert.

Wäre echt nett, wenn mir wer schnell weiterhelfen könnte
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Inkompatibel TStrings und String

  Alt 3. Jun 2005, 16:03
Probier mal:
mycommand.SQL.Textb := einfuegen; Und guck mal in der Hilfe unter Delphi-Referenz durchsuchenTStrings und Delphi-Referenz durchsuchenString nach, da sollte einiges klarer werden.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Iso

Registriert seit: 3. Jun 2005
4 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Inkompatibel TStrings und String

  Alt 3. Jun 2005, 16:17
Ok danke, der fehler ist behoben,

Aber nachdem ich dann die Daten auf meinem formular eingegeben habe und den Button geklickt habe, soll ich den Pfad zu der Datei "mysqlnet.pas" angeben, da er sie beötigt, doch leider findet google da nichts zu.
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

Re: Inkompatibel TStrings und String

  Alt 3. Jun 2005, 16:39
Hai Iso,

ich denke mal er möchte die Datei haben weil es eine Exception gegeben hat.

Zwei Anmerkungen:

a) Verwende als Variablenname nie ein reserviertes Word! name ist ein solches und wenn Du eine Variable so nennst (ausser in einem Record oder ähnlich) wirdst Du immer wieder Probleme bekommen.
b) mySQL möchte, wenn ich mich recht erinnere Strings die Du z.B. bei einem INSERT einfügst in zwei ' eingeschlossen haben.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Iso

Registriert seit: 3. Jun 2005
4 Beiträge
 
Delphi 7 Enterprise
 
#5

Re: Inkompatibel TStrings und String

  Alt 3. Jun 2005, 17:12
Jo, hast recht, war schon blöd von mir n reservierten namen zu benutzen *ausfehlernlerntman*

Und mit dem Insert hatteste auch recht, müssen an jedem ' noch 2 weitere ' angehängt werden in der Insert-Methode
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

Re: Inkompatibel TStrings und String

  Alt 3. Jun 2005, 17:20
Zitat von Iso:
... müssen an jedem ' noch 2 weitere ' angehängt werden in der Insert-Methode
Bevor Du jetzt aber einen String mit lauter ''''' aufbaust schaue Dir mal Delphi-Referenz durchsuchenQuotedStr an

Delphi-Quellcode:
  einfuegen := 'INSERT INTO kunden '
            + 'VALUES(NULL,
            + QuotedStr (dername)
            + ', ' + QuotedStr (passwort)
            + ', ' + QuotedStr(zins)
            + ')';
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Iso

Registriert seit: 3. Jun 2005
4 Beiträge
 
Delphi 7 Enterprise
 
#7

Re: Inkompatibel TStrings und String

  Alt 3. Jun 2005, 17:31
Danke für den Tipp, ieht alles gleich viel übersichtlicher aus!
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

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

Re: Inkompatibel TStrings und String

  Alt 3. Jun 2005, 17:45
Zitat von Iso:
Danke für den Tipp, ieht alles gleich viel übersichtlicher aus!
Wobei das Arbeiten mit Parametern noch besser ist (Ich denke mal myDAC kann das?`)
Delphi-Quellcode:
myquery.SQL := 'INSERT INTO kunden VALUES(NULL, :name , :passwort, :guthaben, :zins)';
myquery.ParamByName ('name').AsString := txtneuname.text;
myquery.ParamByName ('passwort').AsString := txtneupass.text;
myquery.ParamByName ('guthaben').AsString := txtneugut.text;
myquery.ParamByName ('zins').AsString := txtneuzins.text;
myquery.Execute;
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  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 04:03 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