AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Table.Close und Bookmark
Thema durchsuchen
Ansicht
Themen-Optionen

Table.Close und Bookmark

Ein Thema von Klaus D. · begonnen am 19. Dez 2005 · letzter Beitrag vom 19. Dez 2005
Antwort Antwort
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#1

Table.Close und Bookmark

  Alt 19. Dez 2005, 18:05
Datenbank: ADS • Version: 8.0 • Zugriff über: SQL
Hallo
was passiert mit einem Bookmark wenn ich nach dem Bookmarksetzen die Query schließe und wieder öffne.
wenn ich versuche drauf zuzugreifen bekomme ich einen fehler!
Mfg..Klaus
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Table.Close und Bookmark

  Alt 19. Dez 2005, 18:27
Wenn Du die ungeänderte Query schliesst und sofort wieder öffnest, dann sollte es gehen. Aber ein Bookmark ist als Pointer auf einen String definiert (jedenfalls bei ADS) und dieser kann durch das Schliessen der Datenmenge ungültig werden. Ein Bookmark ist auch keinesfalls persistent!

Bessere Lösungen:
  • Recno verwenden
  • Eindeutige ID mit Locate positionieren
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#3

Re: Table.Close und Bookmark

  Alt 19. Dez 2005, 18:29
Das dachte ich mir schon.
Ist es mir möglich ein BsP zu posten.
Danke Klaus
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#4

Re: Table.Close und Bookmark

  Alt 19. Dez 2005, 18:51
Hier ein Beispiel, wo Du die Auswirkungen der verschiedenen Vorgehensweisen siehst:
Delphi-Quellcode:
unit AdsBeispiel;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids, DBGrids, DB, adsdata, adsfunc, adstable, adscnnct;

type
  Tta = class(TForm)
    AdsConnection1: TAdsConnection;
    AdsQuery1: TAdsQuery;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    ButtonSaveBm: TButton;
    ButtonrestoreBm: TButton;
    CheckBoxActive: TCheckBox;
    CheckBoxUseBookMark: TCheckBox;
    procedure FormCreate(Sender: TObject);
    procedure CheckBoxActiveClick(Sender: TObject);
    procedure ButtonrestoreBmClick(Sender: TObject);
    procedure ButtonSaveBmClick(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
    bm : TBookmark;
    Id : string;
  end;

var
  ta: Tta;

implementation

{$R *.dfm}

procedure Tta.ButtonSaveBmClick(Sender: TObject);
begin
  bm := AdsQuery1.GetBookmark;
  Id := AdsQuery1.FieldByName('Id').AsString;
end;

procedure Tta.ButtonrestoreBmClick(Sender: TObject);
begin
  if CheckBoxUseBookMark.Checked then
  begin
    if AdsQuery1.BookmarkValid(Bm) then
       AdsQuery1.GotoBookmark(bm);
  end
  else
  begin
    if id <> 'then
      AdsQuery1.Locate('ID', Id, []);
  end;
end;

procedure Tta.CheckBoxActiveClick(Sender: TObject);
begin
  AdsQuery1.Active := TCheckBox(Sender).Checked;
end;

procedure Tta.FormCreate(Sender: TObject);
begin
  AdsQuery1.Sql.Text := 'Select id, bkz, art, bezeich from bkz';
  AdsQuery1.Active := true;
  Id := '';
end;

end.
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Klaus D.

Registriert seit: 27. Okt 2003
Ort: 03238 Finsterwalde
124 Beiträge
 
Delphi 6 Professional
 
#5

Re: Table.Close und Bookmark

  Alt 19. Dez 2005, 19:03
Ich bin begeistert...Danke und Weihnachten usw.
  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 11:39 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