Zum Inhalt springen

OdbcDataAdapter falsch?


Deletemaster

Empfohlene Beiträge

Hallo zusammen,

ich möchte aus einer mysql-db-Tabelle einen oder mehrere bestimmte Datensätze "holen" und ggf. per Update aktualisieren.

Leider funktioniert der Update-Befehl nicht.

Könnt ihr mir bitte den Fehler zeigen?

Danke

using System;

using System.Drawing;

using System.Collections;

using System.ComponentModel;

using System.Windows.Forms;

using System.Data;

using System.Data.Odbc;


namespace Adressenverwaltung_2

{

	public class Form1 : System.Windows.Forms.Form

	{


		private OdbcConnection conn;

//		private OdbcDataAdapter da;

		private OdbcDataAdapter Upda;

		private OdbcCommandBuilder cb;

		private DataSet ds;

		private System.Windows.Forms.Button btn_Suchen;

		private System.Windows.Forms.Button btn_Aktualisieren;



public Form1()

	{			

		InitializeComponent();


string conStr = 

"Driver={Mysql ODBC 3.51 Driver};SERVER=192.168.1.100;database=adressen;UID=root;Option=3;";


conn = new OdbcConnection(conStr);

//da = new OdbcDataAdapter("SELECT * FROM sparmaxdiapeg", conn);

Upda = new OdbcDataAdapter("SELECT * FROM sparmaxdiapeg WHERE vorname = ? AND nachname = ?", conn);

cb = new OdbcCommandBuilder(Upda);

ds = new DataSet();

dataGrid1.DataSource = ds;

}

{			

			InitializeComponent();


			string conStr = 

				"Driver={Mysql ODBC 3.51 Driver};SERVER=192.168.1.100;database=adressen;UID=root;Option=3;";


			conn = new OdbcConnection(conStr);

//			da = new OdbcDataAdapter("SELECT * FROM sparmaxdiapeg", conn);

			Upda = new OdbcDataAdapter("SELECT * FROM sparmaxdiapeg WHERE vorname = ? AND nachname = ?", conn);

			cb = new OdbcCommandBuilder(Upda);

			ds = new DataSet();

			dataGrid1.DataSource = ds;

		}

static void Main() 

{

	Application.Run(new Form1());

}

private void DS_Suchen()

	{

	string str_Vorname = txt_Vorname.Text;

	string str_Nachname = txt_Nachname.Text;


//	OdbcCommand cmd = new OdbcCommand("SELECT * FROM sparmaxdiapeg WHERE vorname = ? AND nachname = ?", conn);

	OdbcCommand cmd = new OdbcCommand();


cmd.Parameters.Add("vorname", OdbcType.VarChar, 25).Value = str_Vorname;

cmd.Parameters.Add("nachname", OdbcType.VarChar, 25).Value = str_Nachname;

OdbcDataAdapter da = new OdbcDataAdapter(cmd);

DataSet ds = new DataSet();

	try

	{

	da.Fill(ds,"sparmaxdiapeg");

	dataGrid1.DataSource = ds.Tables[0]; 

	}

	catch(Exception ex)

	{

	MessageBox.Show(ex.Message);

	}


}

private void btn_Suchen_Click(object sender, System.EventArgs e)

	{

	DS_Suchen();

	}

	private void DS_Aktualisieren()

	{

	if(ds.HasChanges())

		{

			try

			{

			MessageBox.Show("es soll update folgen");

			Upda.Update(ds,"sparmaxdiapeg");

			MessageBox.Show("Erledigt?");

			}

			catch(Exception ex)

			{

			MessageBox.Show(ex.Message);

			}

		}

	}

private void btn_Aktualisieren_Click(object sender, System.EventArgs e)

{

	DS_Aktualisieren();

}


private void txt_Nachname_TextChanged(object sender, System.EventArgs e)

{

	DS_Suchen();

}

	}

}

Könnt ihr mir vielleicht eine Lösung des Problems zeigen?

Danke

Link zu diesem Kommentar
Auf anderen Seiten teilen

Es wird kein Fehler ausgegeben...

Der Update wird nicht ausgeführt.

Ich denke es liegt irgendwie am Adapter.

Wenn ich ALLE Daten hole (da.Fill)

werden die daten angezeigt und ein ds kann verändert werden

wenn ich einen bestimmten ds suche wird er angezeigt, aber der geänderte ds nicht zurückgeschrieben.

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