Zum Inhalt springen

Datensatz hinzufügen wenn Tabellen in Beziehung stehen.


pez

Empfohlene Beiträge

Hallo nochmal,

es tut mir leid, dass ich schon wieder ein thema erstelle, aber ich konnte wieder mal keine passende hilfe für mich finden (ich glaub, ich bin einfach nur zu blöd, zum suchen +g+)

vorweg: es gibt 2 tabellen (Firma, Aktivitäten); es besteht eine 1:n Beziehung (KdNr, KdNr);

also folgendes:

ich hab eine form, in der 2 datagridviews sind (dbgDaten und dbgAktiv).

im dbgDaten werden alle Kundeninformationen angezeigt, und im dbgAktiv sollen die jeweiligen Aktivitäten der Kunden stehen.

Ich hab einen button, der mir ein unterformular öffnet, in das dann die daten der Aktivitäten geschrieben werden. Drücke ich dann auf den ok button, sollten die Aktivitäten eigentlich gespeichert werden.

doch es wird immer wieder diese meldung angezeigt:

Der Datensatz kann nicht hinzugefügt oder geändert werden, da ein Datensatz in der Tabelle 'Firma' mit diesem Datensatz in Beziehung stehen muss.

ich verstehe diese meldung leider nicht.

Ich schreibe doch immer nur eine KdNr in die Textbox, die es schon gibt.

d.h der kunde ist vorhanden, aber ich kann keine aktivitäten für ihn speichern.

ich hoffe, ich konnte mein problem irgendwie verständlich erläutern und wäre sehr dankbar für eure hilfe.

mein code zum speichern des datensatzes:


 Dim cBuffer As String

        oConn.ConnectionString = cConn

        cBuffer = "INSERT INTO Aktivitäten (KdNr, Datum, Uhrzeit, KonAufPerson, KonArt, KonPerson, Wiedervorlage, Notiz) VALUES (?,?,?,?,?,?,?,?)"

        Dim cmd As New OleDb.OleDbCommand(cBuffer, oConn)


        'Parameter anlegen

        cmd.Parameters.Add("@Datum", OleDb.OleDbType.Date).Value = txtDatum.Text

        cmd.Parameters.Add("@Uhrzeit", OleDb.OleDbType.Char).Value = txtZeit.Text

        cmd.Parameters.Add("@KonAufPerson", OleDb.OleDbType.Char).Value = txtKonAufPers.Text

        cmd.Parameters.Add("@KonArt", OleDb.OleDbType.Char).Value = comKonArt.Text

        cmd.Parameters.Add("@KonPerson", OleDb.OleDbType.Char).Value = txtKonPers.Text

        cmd.Parameters.Add("@Wiedervorlage", OleDb.OleDbType.Char).Value = dtp1.Text

        cmd.Parameters.Add("@Notiz", OleDb.OleDbType.Char).Value = txtNotiz.Text

        cmd.Parameters.Add("KdNr", OleDb.OleDbType.Integer).Value = CType(txtKdNr.Text, Integer)



        'Command ausführen

        If oConn.State <> ConnectionState.Open Then oConn.Open()


        cmd.ExecuteNonQuery()


        Me.Close()

Link zu diesem Kommentar
Auf anderen Seiten teilen

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

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...