AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Access aussergewöhnlicher Fehler bei Unique-Key...?!?
Thema durchsuchen
Ansicht
Themen-Optionen

Access aussergewöhnlicher Fehler bei Unique-Key...?!?

Ein Thema von alexo · begonnen am 1. Dez 2005 · letzter Beitrag vom 5. Dez 2005
Antwort Antwort
Seite 1 von 2  1 2      
alexo

Registriert seit: 30. Nov 2005
36 Beiträge
 
#1

Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 1. Dez 2005, 07:42
Datenbank: Access • Zugriff über: AdoConnection,TAdoQuery,TAdoDataset,TAdoTable...
hallo zusammen!

Hab in meiner Access-DB zwei unique key felder (autowert u. farbcode)..eintragen usw. funktioniert alles. sobald ich die selbe Farbe einfügen möchte kommt - logischerweise - die access fehlermeldung

'änderung konnte nicht vorgenommen werden da der index, primärschlüssel....usw. doppelt vorkommen würde!'

..auch logisch! Wenn ich dann aber eine Farbe einfügen möchte die noch nicht vorhanden ist(zb grau), kommt wieder diese meldung!! Wenn ich das Programm schließe u. wieder öffne, kann ich diese farbe(in diesem fall grau) einfügen...?!?!?


ich weiß wirklich nicht mehr weiter


danke schon mal...
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 1. Dez 2005, 08:45
Hallo alexo,

hast du dieses Verhalten auch direkt im table editor von Access? Ich nicht!

Grüße vom marabu
  Mit Zitat antworten Zitat
alexo

Registriert seit: 30. Nov 2005
36 Beiträge
 
#3

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 1. Dez 2005, 10:41
direkt in access hab ich es auch nicht

k.a.

was kann man da machen, bzw. woran liegt dass?!?!?!?
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#4

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 1. Dez 2005, 10:57
Zitat von alexo:
was kann man da machen, bzw. woran liegt dass?!?!?!?
Dann zeig uns mal etwas Code. Über welche Kompos greifst Du auf die Datenbank zu... ADO oder nativ?
  Mit Zitat antworten Zitat
alexo

Registriert seit: 30. Nov 2005
36 Beiträge
 
#5

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 1. Dez 2005, 11:18
sieh doch mal in die überschrift

ado...

das ist meine speicher funktion

Delphi-Quellcode:
procedure TFrmKategorieErstellen.SaveNew(TblKat,TblFarb:TADOTable; EdtName:TEdit);
var
  HoechsteNr: Integer;
begin
    TblKat.Active := True;
    TblFarb.Active := True;
    TblKat.Append;
    TblFarb.Append;
    TblKat.FieldByName('KategorieName').AsString := Edtname.Text;
    TblKat.FieldByName('KategorieArtEinnahme').AsBoolean := rdbEinnahme.Checked;
    //KategorieNr ermitteln
      with Datamodule1.AdoQuery1 do
      begin
        active := false;
        Sql.Clear;
        Sql.Add('Select Max(KategorieNr) As HoechsteNr');
        Sql.Add('from TblKategorie');
        active := true;
        HoechsteNr := FieldByName('HoechsteNr').AsInteger;
      end;
    TblKat.FieldByName('KategorieNr').AsInteger := (HoechsteNr + 1);
    TblFarb.FieldByName('FarbcodeNr').AsInteger := clb.ItemIndex;
    TblFarb.FieldByName('FarbCodeText').AsString := ColorToString(clb.selected);
    TblKat.FieldByName('FarbCode').AsInteger := TblFarb.FieldByName('FarbCodeNr').AsInteger;
    TblKat.Post;
    TblFarb.Post;
end;
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#6

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 1. Dez 2005, 13:49
Ich denke dein Problem ist, dass bei einem 2. Aufruf, deine 2 Tabellen bereits auf Active stehen. Setz doch mal dein Post in einen try...except Block und mach ein Cancel im Except Teil. So, wie du es hast, schlägt der Post fehl, und bei einem erneuten Aufruf deiner Prozedur bist du immer noch im Append Modus. Besser also, schön sauber deine vorherige Aktion zu canceln.
  Mit Zitat antworten Zitat
alexo

Registriert seit: 30. Nov 2005
36 Beiträge
 
#7

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 1. Dez 2005, 13:59
danke!!!!!

funktioniert

auf das "canceln" wär ich nie gekommen *gg*..... hab den except block zuvor wieder raus genommen weil er mir ohne cancel logischerweise nicht viel gebracht hat


danke nochmal...
  Mit Zitat antworten Zitat
alexo

Registriert seit: 30. Nov 2005
36 Beiträge
 
#8

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 5. Dez 2005, 10:27


hab jetzt das ganze WE damit verbracht den fehler zu beheben:

eigentlich hat alles funktioniert(post usw.)

plötzlich führt er den post aber nicht mehr aus hier der
code:

Delphi-Quellcode:
function TFrmKategorieErstellen.SaveNew(TblKat,TblFarb:TADOTable; EdtName:TEdit):Boolean;
var
  HoechsteNr: Integer;
begin
    TblKat.Active := True;
    TblFarb.Active := True;
    TblKat.Append;
    TblFarb.Append;
    TblKat.FieldByName('KategorieName').AsString := Edtname.Text;
    TblKat.FieldByName('KategorieArtEinnahme').AsBoolean := rdbEinnahme.Checked;
    //KategorieNr ermitteln
      with Datamodule1.AdoQuery1 do
      begin
        active := false;
        Sql.Clear;
        Sql.Add('Select Max(KategorieNr) As HoechsteNr');
        Sql.Add('from TblKategorie');
        active := true;
        HoechsteNr := FieldByName('HoechsteNr').AsInteger;
      end;
    TblKat.FieldByName('KategorieNr').AsInteger := (HoechsteNr + 1);
    TblFarb.FieldByName('FarbcodeNr').AsInteger := clb.ItemIndex;
    TblFarb.FieldByName('FarbCodeText').AsString := ColorToString(clb.selected);
    TblKat.FieldByName('FarbCode').AsInteger := TblFarb.FieldByName('FarbCodeNr').AsInteger;
    try
    TblKat.Post;
    TblFarb.Post;
    Result := True;
    except
    on E: Exception do
    begin
    Application.MessageBox('Farbe bereits in Verwendung!','Warnung',48);
    TblKat.Cancel;
    TblFarb.Cancel;
    Result := False;
    end;
    end;
end;
beim debuggen bleibt er bei der ersten post anweisung stehen...

keine ahnung warum...
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#9

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 5. Dez 2005, 11:27
Hallo Alex,

in der MessageBox solltest du E.Message ausgeben - eventuell erfährst du dann eine ganz andere Fehlerursache, als die vermutete.

Übrigens ist deine Methode zur Ermittlung einer neuen KategorieNr in einer Mehrbenutzerumgebung unsicher.

Grüße vom marabu
  Mit Zitat antworten Zitat
alexo

Registriert seit: 30. Nov 2005
36 Beiträge
 
#10

Re: Access aussergewöhnlicher Fehler bei Unique-Key...?!?

  Alt 5. Dez 2005, 11:39
wenn ich die zeile so ändere

Application.MessageBox(E.Message,'Warnung',48); meldet der compiler: inkompatible typen String u. PAnsiChar


sry hab noch nie einen PAnsiChar umgewandelt
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 10:15 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