AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Value in MS SQL Datenbank schreiben

Value in MS SQL Datenbank schreiben

Ein Thema von arcon · begonnen am 8. Jun 2010 · letzter Beitrag vom 9. Jun 2010
Antwort Antwort
arcon

Registriert seit: 8. Jun 2010
71 Beiträge
 
#1

AW: Value in MS SQL Datenbank schreiben

  Alt 9. Jun 2010, 09:32
Hallo,

ich würde gerne folgende Sache machen.

Ich habe mir eine ADO-Connection aufgebaut. Dazu gehört eine TADODataSet-, TADODataSource- und eine TADOCommand-Komponente.

In dieser TADOCommand-Komponente habe ich unter dem Befehl Command.Text folgenden SQL Befehl eingefügt:

SQL-Code:
Insert into test(test,tewst2,Ctest3)
               Values(
                 ''11'',
                 ''10.10.2010 00:00:00'',
                 ''A_My_Continent'',
                )
Meine Tabelle lautet test und die 3 Spalten lauten Ebenfalls test, tewst2 und test 3.
die 3 Werte möchte ich erstmal so, wie oben einfügen und NICHT über Parameterübergaben, um erstmal die Funktionsweise zu verstehen.

in Delphi hab ich mir einen Button erzeugt. wenn ich auf diesen klicke, soll er mir den oben genannten SQL befehl ausführen.

dazu habe ich folgenden code in delphi eingefügt:

Delphi-Quellcode:
procedure TForm1.Button3Click(Sender: TObject);
var
Adocommand1:TADOcommand;
begin

     Adocommand1.Execute;

end;
nun zu meinem problem... so wie ich es eben beschrieben habe, macht das programm díe ausführung nicht.

woran könnte das liegen ?

wäre für tipps dankbar.

gruß arcon

Geändert von mkinzler ( 9. Jun 2010 um 09:34 Uhr) Grund: SQL/Delphi-Tag eingefügt
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.882 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Value in MS SQL Datenbank schreiben

  Alt 9. Jun 2010, 09:35
Du musst ggf die Transaktion noch commiten
Markus Kinzler
  Mit Zitat antworten Zitat
arcon

Registriert seit: 8. Jun 2010
71 Beiträge
 
#3

AW: Value in MS SQL Datenbank schreiben

  Alt 9. Jun 2010, 09:57
okay .. ich habe folgenden code in den SQL-Teil eingefügt

SQL-Code:
Use test;
go
begin transaction;
go
Insert into test(test,tewst2,test3)
               Values(
                 ''11'',
                 ''10.10.2010 00:00:00'',
                 ''A_My_Continent'',
                )
commit transaction;
Go
bin auf ausführen gegangen und dann bringt er mir folgende fehlermeldung :

Im Projekt Stand_100609.exe ist eine Exception der Klasse EAccessViolation mit der Meldung "Zugriffsv erletzung bei Adresse 0059C3De in Modul "Stand_100609.exe, Lesen von Adresse 000000000 aufgetreten.
Ich habe ausserdem mal versucht, den Delphi-Quellcode auszukommentieren, um zu schauen, ob der fehler dann immer noch vorhanden ist .. und siehe da, er ist es nicht mehr .. also muss es an dem delphi-quellcode liegen ..

was heißt diese fehlermeldung ?
kann mir jemand da weiterhelfen ?

ist die commit aktion so richtig ? @ mkinzler

danke für deine Hilfe

Geändert von mkinzler ( 9. Jun 2010 um 10:30 Uhr) Grund: Erweiterung
  Mit Zitat antworten Zitat
Christian Seehase
(Co-Admin)

Registriert seit: 29. Mai 2002
Ort: Hamburg
11.124 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Value in MS SQL Datenbank schreiben

  Alt 9. Jun 2010, 10:14
Moin arcon,

ich denke, ich habe den Fehler gefunden:

Hier

Code:
''A_My_Continent'',
muss das Komma am Ende weg, danach kommt nämlich die Klammer von VALUES
Tschüss Chris
Die drei Feinde des Programmierers: Sonne, Frischluft und dieses unerträgliche Gebrüll der Vögel.
Der Klügere gibt solange nach bis er der Dumme ist
  Mit Zitat antworten Zitat
arcon

Registriert seit: 8. Jun 2010
71 Beiträge
 
#5

AW: Value in MS SQL Datenbank schreiben

  Alt 9. Jun 2010, 10:41
Hallo,

ich habe gerade mal deinen Hinweis abgeändert, muss aber jedoch feststellen, dass dies nicht der Fehler ist bzw. ein fehler ist, aber nicht der , der die fehlermeldung verursacht.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.669 Beiträge
 
Delphi 12 Athens
 
#6

AW: Value in MS SQL Datenbank schreiben

  Alt 9. Jun 2010, 10:47
"Lesen von Adresse 000000000" deutet darauf hin, dass Du auf ein Objekt zugreifen willst, das Du gar nicht angelegt/instanziert hast.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
arcon

Registriert seit: 8. Jun 2010
71 Beiträge
 
#7

AW: Value in MS SQL Datenbank schreiben

  Alt 9. Jun 2010, 11:41
Ich habe das Problem gelöst.

Folgenden Quellcode müsst Ihr in Delphi einfügen

Code:
procedure InsertThingsIntoDatabase;
var
  adoConn: TADOConnection;
  adoCmd: TADOCommand;
  begin
  try
    try
      adoConn := TADOConnection.Create(nil);
      adoConn.ConnectionString := 'Provider=Microsoft.SQLSERVER.CE.OLEDB.3.5;Data Source=//EureDatenbank//';

      adoConn.Open;

      adoCmd := TADOCommand.Create(nil);
      adoCmd.Connection := adoConn;
      adoCmd.CommandText := 'INSERT INTO //EurerTabellenname// (feld1, feld2) VALUES (:feld1, :feld2);';

      adoCmd.Prepared := true;

      adoCmd.Parameters[0].Value := 'Test';
      adoCmd.Parameters[1].Value := 'Test';
     
     

    except
            end;
  finally
    adoConn.Close;
    adoCmd.Free;
    adoConn.Free;
    end;
end;
Danke für die Unterstützung.
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 02:21 Uhr.
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