Delphi-PRAXiS
Seite 18 von 36   « Erste     8161718 192028     Letzte »    

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Tutorials und Kurse (https://www.delphipraxis.net/36-tutorials-und-kurse/)
-   -   Delphi MySQL ohne Komponenten (https://www.delphipraxis.net/6543-mysql-ohne-komponenten.html)

freak4fun 9. Sep 2006 22:41

Re: MySQL ohne Komponenten
 
Zitat:

Zitat von Chewie
Zitat:

Zitat von freak4fun
>.< Mit der SQL-Abfrage komme ich net klar. :(


Also wenn du schon mit dem SHOW TABLES Probleme hast, würde ich dir dringendst anraten, dich mit SQL vertraut zu machen, bevor du programmatisch mit einer Datenbank kommunizieren willst.

Hab ich bis jetzt noch nicht gebraucht, also kann ich es nicht. Nach etwas rumprobieren hab ich es aber dann doch geschafft. Ich lerne halt immer nur das, was ich brauch. ;)

MfG
freak

Chewie 10. Sep 2006 09:18

Re: MySQL ohne Komponenten
 
Zitat:

Zitat von BaedDog
Aber ich hab 'ne Frage, wie kann ich rausfinden ob ein Feld einer Abfrage NULL ist? Bei einer Abfrage werden diese ja automatisch in ein leeren String umgewandelt.

Die Ergebnisse sind ja keine direkten Strings, sondern PChars. Und die können NULL bzw. NIL sein. Und laut MySQL-Doku sind sie das auch in diesem Fall.

BaedDog 10. Sep 2006 17:37

Re: MySQL ohne Komponenten
 
Zitat:

Zitat von Chewie
Die Ergebnisse sind ja keine direkten Strings, sondern PChars. Und die können NULL bzw. NIL sein. Und laut MySQL-Doku sind sie das auch in diesem Fall.

Ah geht doch, hatte immer versucht das Ergebnis mit = NULL abzufragen, hatte vergessen das in Delphi alles nil ist ^^

eLem3ntx 3. Okt 2006 12:49

Re: MySQL ohne Komponenten
 
Bei mir funzt es mit der Connection wirklich n1 Super TUT jedoch kommt bei der zweiten Verbindung immer ein Fehler dass in der libmySQL.dll zugriffsverletzungen seien.
Und das insert into geht nit, Zahlen gehen aber variablen oder strings nicht:
Delphi-Quellcode:
var
 var1, var2: string;
...

var1 := 'Name';
var2 := 'TestText :D';

...

query := 'INSERT INTO delphi (name, text) VALUES (var1, var2)';
mysql_real_query(_myCon, query, Length(query));
Das funkt einfach nicht kommt auch keine Fehlermeldung oder so
Jedoch so funkt es:
Delphi-Quellcode:
query := 'INSERT INTO delphi (name, text) VALUES (1, 2)';
mysql_real_query(_myCon, query, Length(query));
Dann wird die 1 und die 2 eingetragen! Komisch oder??^^ Weiß jemand eine Antwort, thx im Vorraus :D

mkinzler 3. Okt 2006 12:56

Re: MySQL ohne Komponenten
 
Delphi-Quellcode:
query := 'INSERT INTO delphi (name, text) VALUES ('+QuotedStr(var1)+', '+QuotedStr( var2)'+ ');';

eLem3ntx 3. Okt 2006 13:18

Re: MySQL ohne Komponenten
 
Ok erstmal danke (mkinzler du bist ja echt wirklich sehr aktiv :D)
Jedoch sagt BDES dann im Debug modus <<[Pascal Fehler] Unit1.pas(82): E2010 Inkompatible Typen: 'string' und 'PAnsiChar'>>

Liegt es vtl. daran dass die vars strings sind? Ind er DB sind die 2 spalten als "text" markiert.

mkinzler 3. Okt 2006 13:22

Re: MySQL ohne Komponenten
 
Zitat:

Liegt es vtl. daran dass die vars strings sind? Ind er DB sind die 2 spalten als "text" markiert.
Nein, es liegt an der Funktion aus der Dll.

Versuch mal:
Delphi-Quellcode:
mysql_real_query(_myCon, PChar(query), Length(query));

eLem3ntx 3. Okt 2006 13:27

Re: MySQL ohne Komponenten
 
Zitat:

Zitat von mkinzler
Zitat:

Liegt es vtl. daran dass die vars strings sind? Ind er DB sind die 2 spalten als "text" markiert.
Nein, es liegt an der Funktion aus der Dll.

Versuch mal:
Delphi-Quellcode:
mysql_real_query(_myCon, PChar(query), Length(query));

Nein funktioniert leider auch nicht da die INSERT INTO Zeile ja zuerst kommt und da diese ja schon als "falsch" markiert wird kommt es gar nicht zum mysql_real_query.
hab auch mal folgendes versucht:
Delphi-Quellcode:
query := 'INSERT INTO delphi (name, text) VALUES ('+var1+', '+var2+')';
Dort kommt jedoch der gleiche Fehler wie bei deinem query (QuotedStr...).

Hab auch schon versucht die vars als PChar zu setzen, jedoch ohne Erfolg :(
Aber so was muss ja möglich sein!! :wall:

mkinzler 3. Okt 2006 13:31

Re: MySQL ohne Komponenten
 
Delphi-Quellcode:
query := 'INSERT INTO delphi (name, text) VALUES ('+PCahr(QuotedStr(var1))+', '+PChar(QuotedStr( var2))'+ ');';

eLem3ntx 3. Okt 2006 13:50

Re: MySQL ohne Komponenten
 
Hmm geht leider immer noch nicht sagt immer noch den gleichen Fehler dass es inkompatibel mit Pchar oder string sei!


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:17 Uhr.
Seite 18 von 36   « Erste     8161718 192028     Letzte »    

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-2025 by Thomas Breitkreuz