AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Von ADOQuery zu ADSQuery
Thema durchsuchen
Ansicht
Themen-Optionen

Von ADOQuery zu ADSQuery

Ein Thema von Kevin · begonnen am 26. Mai 2004 · letzter Beitrag vom 31. Mai 2004
Antwort Antwort
Seite 1 von 3  1 23      
Benutzerbild von Kevin
Kevin

Registriert seit: 11. Feb 2004
Ort: Bonn
576 Beiträge
 
Delphi 2006 Professional
 
#1

Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 16:01
Hallo Leute,

ich brauche Hilfe beim Umstellen von Access auf ADS.

Die folgende, von Gollum in diesem Thread gepostete TADOQuery, brauche ich dringend als TADSQUery, bekomme es aber leider nicht hin...

Code:
// folgendes Beispiel geht einem 3-Spaltigen Stringgrid aus


var aQry:TADOQuery;
     y:Integer;
    sQry:String;
...
aQry:=TADOQuery.Create(nil);
try
  aQry.Connection:=ADOConnection1;
  sQry:='INSERT INTO tabelle (Feld1, Feld2, Feld3) VALUES(:v1, :v2, :v3)';
  for y:=1 to StringGrid1.RowCount do
  begin
    aQry.SQL.Text:=sQry;
    with aQry.Parameters do
    begin
      ParamValues['v1']:=StringGrid1.Cells[0, y];
      ParamValues['v2']:=StringGrid1.Cells[1, y];
      ParamValues['v3']:=StringGrid1.Cells[2, y];
    end; // with
    aQry.ExecSQL;
  end; // for y
finally
  aQry.Free;
end; // try

Ein Durchsuchen der DP nach nahezu allen möglichen Suchbegriffen in Bezug auf ADS und Queries hat leider kein Ergebnis gebracht...

Ich zähl auf Euch
Kevin
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#2

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 17:56
Wo hakt es denn?
  Mit Zitat antworten Zitat
Benutzerbild von Kevin
Kevin

Registriert seit: 11. Feb 2004
Ort: Bonn
576 Beiträge
 
Delphi 2006 Professional
 
#3

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 18:26
Hallo r_kerber,

bei aQry.Connection:=MeineADSConnection; kommt die Fehlermeldung "Undefinierter Bezeichner: 'Connection'". Und damit kann ich auch nicht testen, ob der Rest funktioniert...
Kevin
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#4

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 18:31
Was hälts Du von aQry.DatabaseName?
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#5

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 18:35
Zitat von Kevin:
Code:
// folgendes Beispiel geht einem 3-Spaltigen Stringgrid aus

var aQry:TADOQuery;
     y:Integer;
    sQry:String;
...
aQry:=TADOQuery.Create(nil);
try
  aQry.Connection:=ADOConnection1;
  sQry:='INSERT INTO tabelle (Feld1, Feld2, Feld3) VALUES(:v1, :v2, :v3)';
  for y:=1 to StringGrid1.RowCount do
  begin
    aQry.SQL.Text:=sQry;
    with aQry.Parameters do
    begin
      ParamValues['v1']:=StringGrid1.Cells[0, y];
      ParamValues['v2']:=StringGrid1.Cells[1, y];
      ParamValues['v3']:=StringGrid1.Cells[2, y];
    end; // with
    aQry.ExecSQL;
  end; // for y
finally
  aQry.Free;
end; // try
Du weisst die Eigenschaft SQL.Text innerhalb der Schleife zu. Das ist bestimmt nicht günstig ( )
für die Parameter-Objekte, da diese jedesmal aus der SQL-Anweisung geparst werden.
Deshalb:
Delphi-Quellcode:
aQry:=TADOQuery.Create(nil);
try
  aQry.Connection:=ADOConnection1;
  aQry.SQL.Text:='INSERT INTO tabelle (Feld1, Feld2, Feld3) VALUES(:v1, :v2, :v3)';
  for y:=1 to StringGrid1.RowCount do
  begin
Manchmal ist ADO nicht in der Lage, die Datentypen der Parameter korrekt zu ermitteln.
(dies hängt vom OLE-DB Provider ab; auch die VCL hat hier möglicherweise noch Bugs)
Dann muss man nachhelfen:
Delphi-Quellcode:
aQry.SQL.Text:='INSERT INTO tabelle (Feld1, Feld2, Feld3) VALUES(:v1, :v2, :v3)';
  aQry.Parameters.ParamByName('v1').Datatype := dtInteger;
  ...
  for y:=1 to StringGrid1.RowCount do
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von Kevin
Kevin

Registriert seit: 11. Feb 2004
Ort: Bonn
576 Beiträge
 
Delphi 2006 Professional
 
#6

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 18:45
Zitat von r_kerber:
Was hälts Du von aQry.DatabaseName?
Ist mir ein wenig peinlich , aber bei DatabaseName weiß ich nicht, was ich eintragen soll. Ich hab eine ADSConnection, eine ADSTable und eine ADSQuery angelegt und den ALS-Alias wird ebensowenig akzeptiert...

Zudem kommt noch eine weitere Fehlermeldung: "Undefinierter Bezeichner: 'parameters'". Scheint TADSQuery auch nicht zu kennen.

Ich steh momentan ein wenig auf dem Schlauch und mit dem Rücken zur Wand. Entschuldigt bitte meine Extremblockade...

Zitat von shmia:
Du weisst die Eigenschaft SQL.Text innerhalb der Schleife zu. Das ist bestimmt nicht günstig
Hallo shmia,

die Prozedur hat aber prima ihren Dienst verrichtet. Ich werde aber Deine Vorschläge mal mit ADO testen, obwohl ich das Vertrauen in ADO so ziemlich verloren habe und im Begriff bin zu ADS/ALS zu wechseln.
Kevin
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#7

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 19:12
Hallo Kevin,

zunächst die Frage warum Table und Query? Eines von beiden reicht!

Und jetzt, wo Du es sagst, merke ich auch, dass AdsQuery ein wenig anders arbeitet als z.B ADSTable.
So hat's aber bei mir funktioniert:
  AdsQuery1.DatabaseName := AdsConnectionTest.Name;
  Mit Zitat antworten Zitat
Benutzerbild von Kevin
Kevin

Registriert seit: 11. Feb 2004
Ort: Bonn
576 Beiträge
 
Delphi 2006 Professional
 
#8

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 19:27
Zitat von r_kerber:
Hallo Kevin,

zunächst die Frage warum Table und Query? Eines von beiden reicht!
Die Query schreibt doch lediglich die Daten des StringGrids in eine Table. Dazu brauche ich doch beides, oder nicht?

Zitat von r_kerber:
  AdsQuery1.DatabaseName := AdsConnectionTest.Name;
Ja, das sieht doch gleich viel besser aus. Nun hängt er halt an den undefinierten 'Parameters' und 'ParamValues'...
Kevin
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#9

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 21:10
Zitat von Kevin:
Die Query schreibt doch lediglich die Daten des StringGrids in eine Table. Dazu brauche ich doch beides, oder nicht?
In eine Tabelle ja, aber nicht unbedingt in ADSTable.
Zitat von Kevin:
Nun hängt er halt an den undefinierten 'Parameters' und 'ParamValues'...
Wie sieht Dein SQL-Statement aus?
  Mit Zitat antworten Zitat
Benutzerbild von Kevin
Kevin

Registriert seit: 11. Feb 2004
Ort: Bonn
576 Beiträge
 
Delphi 2006 Professional
 
#10

Re: Von ADOQuery zu ADSQuery

  Alt 26. Mai 2004, 23:50
Zitat von r_kerber:
Zitat von Kevin:
Die Query schreibt doch lediglich die Daten des StringGrids in eine Table. Dazu brauche ich doch beides, oder nicht?
In eine Tabelle ja, aber nicht unbedingt in ADSTable.
In was für eine Tabelle denn sonst?


Zitat von r_kerber:
Zitat von Kevin:
Nun hängt er halt an den undefinierten 'Parameters' und 'ParamValues'...
Wie sieht Dein SQL-Statement aus?
Im Prinzip so wie das Beispiel oben:

Code:
  aQry:=TADSQuery.Create(nil);
  try
    aQry.DatabaseName:=DataModule2.ADSConnection.Name;
    aQry.SQL.Text :='INSERT INTO Import '+
          '(Feld1, Feld2, Feld3, Feld4, Feld5, '+
          ... //gekürzt  
          'Feld36)'+
          ' VALUES(:v1, :v2, :v3, :v4, :v5, :v6, :v7, :v8, :v9, :v10, '+
          ':v11, :v12, :v13, :v14, :v15, :v16, :v17, :v18, :v19, :v20, '+
          ':v21, :v22, :v23, :v24, :v25, :v26, :v27, :v28, :v29, :v30, '+
          ':v31, :v32, :v33, :v34, :v35, :v36)';
    for y:=1 to ImportGrid.RowCount -1 do
    begin
      with aQry.Parameters do
      begin
        ParamValues['v1']:=ImportGrid.Cells[0, y];
        ParamValues['v2']:=ImportGrid.Cells[1, y];
        ParamValues['v3']:=ImportGrid.Cells[2, y];
        ParamValues['v4']:=ImportGrid.Cells[3, y];
        ParamValues['v5']:=ImportGrid.Cells[4, y];
        ParamValues['v6']:=ImportGrid.Cells[5, y];
        ParamValues['v7']:=ImportGrid.Cells[6, y];
        ParamValues['v8']:=ImportGrid.Cells[7, y];
        ParamValues['v9']:=ImportGrid.Cells[8, y];
        ParamValues['v10']:=ImportGrid.Cells[9, y];
        ParamValues['v11']:=ImportGrid.Cells[10, y];
        ParamValues['v12']:=ImportGrid.Cells[11, y];
        ParamValues['v13']:=ImportGrid.Cells[12, y];
        ParamValues['v14']:=ImportGrid.Cells[13, y];
        ParamValues['v15']:=ImportGrid.Cells[14, y];
        ParamValues['v16']:=ImportGrid.Cells[15, y];
        ParamValues['v17']:=ImportGrid.Cells[16, y];
        ParamValues['v18']:=ImportGrid.Cells[17, y];
        ParamValues['v19']:=ImportGrid.Cells[18, y];
        ParamValues['v20']:=ImportGrid.Cells[19, y];
        ParamValues['v21']:=ImportGrid.Cells[20, y];
        ParamValues['v22']:=ImportGrid.Cells[21, y];
        ParamValues['v23']:=ImportGrid.Cells[22, y];
        ParamValues['v24']:=ImportGrid.Cells[23, y];
        ParamValues['v25']:=ImportGrid.Cells[24, y];
        ParamValues['v26']:=ImportGrid.Cells[25, y];
        ParamValues['v27']:=ImportGrid.Cells[26, y];
        ParamValues['v28']:=ImportGrid.Cells[27, y];
        ParamValues['v29']:=ImportGrid.Cells[28, y];
        ParamValues['v30']:=ImportGrid.Cells[29, y];
        ParamValues['v31']:=ImportGrid.Cells[30, y];
        ParamValues['v32']:=ImportGrid.Cells[31, y];
        ParamValues['v33']:=ImportGrid.Cells[32, y];
        ParamValues['v34']:=ImportGrid.Cells[31, y];
        ParamValues['v35']:=ImportGrid.Cells[32, y];
        ParamValues['v34']:=ImportGrid.Cells[33, y];
        ParamValues['v35']:=ImportGrid.Cells[34, y];
        ParamValues['v36']:=ImportGrid.Cells[35, y];
      end; // with
      aQry.ExecSQL;
    end; // for y
  finally
    aQry.Free;
  end; // try
end;
Kevin
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 08:32 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