Zum Inhalt springen

C# - Tableadapter


Empfohlene Beiträge

Geschrieben

Hallo liebe Leute,

ich sehe mal wieder gewaltig auf dem Schlauch. Vorhanden ist eine C#, diese greift über die ODT Tools auf eine Oracle-Datenbank zu. Die Anwendung hat

auf einer Form einen Tableadapter. Dort ist als Insert Statement folgendes eingetragen.

insert into Unternehmen (NR,Name) values ((select max(rownum) from Unternehmen), Name)

Mit diesen Statement erhalte ich die Fehlermeldung das nr keinen Wert enthalten würde ( also zur Laufzeit ). Ich habe aber keine Idee warum das

so ist, das Subselect sollte doch eigentlich die Nummer liefern. Im Oracle

SQL Developer geht das ja auch mit genau dem gleichen Befehl.

Mir ist bekannt das es besser mit sequence und trigger geht, im Moment geht es mir aber nur darum ob subselects im Tableadapter zuläßig sind, oder halt nicht.

Mit freundlichen Grüen

Harry

Geschrieben

Ich halte RowNum hier für ungeeignet. Ich weiß allerdings nicht, wie weit DML bei dieser Tabelle angewendet wird (also, ob auch gelöscht wird).

Du hast bspw. 3 Zeilen (ich geh mal davon aus, das Nr PK ist und Name ein String):

1 abc

2 def

3 ghi

Dann löscht man Zeile 1, folglich wird bei max(rownum) auf 2 gesetzt.

ergo:

2 def <-- rownum 1

3 ghi <-- rownum 2

2 abc <-- max(rownum) == 2; PK nicht mehr eindeutig - Fehler

Daher würd ich hier eher zu MAX(NR)+1 tendieren.

Formal betrachtet funktionieren aber SubSelects in TableAdapter.

(Dafür gibts ja die Property InsertCommand...)

Geschrieben

Hallo TDM,

Daher würd ich hier eher zu MAX(NR)+1 tendieren.

Formal betrachtet funktionieren aber SubSelects in TableAdapter.

(Dafür gibts ja die Property InsertCommand...)

Ja du hast recht. +1 wäre in jeden Fall sinnvoll. Es ist manchmal

verhext, ich habe den halben Tag damit verbracht einen Fehler

zu suchen und nach dem Mittag sieht wieder alles ganz anders

aus. In der MSDN habe ich mich nochmal gründlich in den Table-

Adapter eingelesen und nun läuft das auch so wie gewollt. Danke

aber für den Hinweis mit max(nr)+1

Harry

Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...