Hallo!<br>
<p>Ich benutzte ADO.net und möchte folgendes tun:
<br>
1. -> Transaction eröffnen<br>
2. Einige Inserts schreiben<br>
3. Select über ne Menge Daten schieben<br>
4. Noch ein Insert schreiben<br>
5. -> Transaction beenden<br>
6. den Container mit dem Select auslesen<br>
<p>Nun passiert aber folgendes: Das mit dem SQLDataReader funzt nicht. Schliesst der einfach meine Transaction?<br>
<PRE>
Console.WriteLine("Test");
string myConnString="user id=root;password=root;initial catalog=ilmtest;data source=192.168.1.35\\VSdotNET;Connect Timeout=60;Integrated Security=SSPI";
SqlConnection myConnection = new SqlConnection(myConnString);
myConnection.Open();
SqlCommand myCommand = new SqlCommand();
SqlTransaction myTrans;
myTrans = myConnection.BeginTransaction();
myCommand.Connection = myConnection;
myCommand.Transaction = myTrans;
SqlDataReader myReader;
try
{
myCommand.CommandText = "INSERT INTO tdatentypen (ztextid_fk, ztinyint, zsmallint, zint, zbigint, zfloat, zdouble, zvarchar, ztext) VALUES (1,3,2,44444,55555,0.1111, 0.2222, 'Kuckuk', 'Nasenbaer');";
myCommand.ExecuteNonQuery();
myCommand.CommandText = "INSERT INTO tdatentypen (ztextid_fk, ztinyint, zsmallint, zint, zbigint, zfloat, zdouble, zvarchar, ztext) VALUES (1,3,2,44444,55555,0.1111, 0.2222, 'Kuckuk', 'Nasenbaer');";
myCommand.ExecuteNonQuery();
myCommand.CommandText = "SELECT * FROM tdatentypen";
myReader = myCommand.ExecuteReader(System.Data.CommandBehavio r.Default);
myCommand.CommandText = "INSERT INTO tdatentypen (ztextid_fk, ztinyint, zsmallint, zint, zbigint, zfloat, zdouble, zvarchar, ztext) VALUES (1,3,2,44444,55555,0.1111, 0.2222, 'Kuckuk', 'Nasenbaer');";
myCommand.ExecuteNonQuery();
myReader.Close();
myTrans.Commit();
while (myReader.Read())
{
Console.WriteLine(myReader.GetString(8));
}
Console.WriteLine("Both records are written to database.");
}
catch(Exception e)
{
myTrans.Rollback();
Console.WriteLine("Error: {1}", e.Message);
Console.WriteLine("Error reported by {1}.", e.Source);
Console.WriteLine("Neither record was written to database.");
}
finally
{
myConnection.Close();
}
</PRE>
<p>Das Beispiel ist wenig sinnvoll. Aber meine eigentliche Anwendung schon. Nur wäre das hier zu lang .... deswegen diese Abstraktion. Vielleicht hat ja wer nen Tip.
<br>
Christian Zink
<p>Ich benutzte ADO.net und möchte folgendes tun:
<br>
1. -> Transaction eröffnen<br>
2. Einige Inserts schreiben<br>
3. Select über ne Menge Daten schieben<br>
4. Noch ein Insert schreiben<br>
5. -> Transaction beenden<br>
6. den Container mit dem Select auslesen<br>
<p>Nun passiert aber folgendes: Das mit dem SQLDataReader funzt nicht. Schliesst der einfach meine Transaction?<br>
<PRE>
Console.WriteLine("Test");
string myConnString="user id=root;password=root;initial catalog=ilmtest;data source=192.168.1.35\\VSdotNET;Connect Timeout=60;Integrated Security=SSPI";
SqlConnection myConnection = new SqlConnection(myConnString);
myConnection.Open();
SqlCommand myCommand = new SqlCommand();
SqlTransaction myTrans;
myTrans = myConnection.BeginTransaction();
myCommand.Connection = myConnection;
myCommand.Transaction = myTrans;
SqlDataReader myReader;
try
{
myCommand.CommandText = "INSERT INTO tdatentypen (ztextid_fk, ztinyint, zsmallint, zint, zbigint, zfloat, zdouble, zvarchar, ztext) VALUES (1,3,2,44444,55555,0.1111, 0.2222, 'Kuckuk', 'Nasenbaer');";
myCommand.ExecuteNonQuery();
myCommand.CommandText = "INSERT INTO tdatentypen (ztextid_fk, ztinyint, zsmallint, zint, zbigint, zfloat, zdouble, zvarchar, ztext) VALUES (1,3,2,44444,55555,0.1111, 0.2222, 'Kuckuk', 'Nasenbaer');";
myCommand.ExecuteNonQuery();
myCommand.CommandText = "SELECT * FROM tdatentypen";
myReader = myCommand.ExecuteReader(System.Data.CommandBehavio r.Default);
myCommand.CommandText = "INSERT INTO tdatentypen (ztextid_fk, ztinyint, zsmallint, zint, zbigint, zfloat, zdouble, zvarchar, ztext) VALUES (1,3,2,44444,55555,0.1111, 0.2222, 'Kuckuk', 'Nasenbaer');";
myCommand.ExecuteNonQuery();
myReader.Close();
myTrans.Commit();
while (myReader.Read())
{
Console.WriteLine(myReader.GetString(8));
}
Console.WriteLine("Both records are written to database.");
}
catch(Exception e)
{
myTrans.Rollback();
Console.WriteLine("Error: {1}", e.Message);
Console.WriteLine("Error reported by {1}.", e.Source);
Console.WriteLine("Neither record was written to database.");
}
finally
{
myConnection.Close();
}
</PRE>
<p>Das Beispiel ist wenig sinnvoll. Aber meine eigentliche Anwendung schon. Nur wäre das hier zu lang .... deswegen diese Abstraktion. Vielleicht hat ja wer nen Tip.
<br>
Christian Zink
Comment