Mercurial > pub > bltoolkit
diff HowTo/DataAccess/Update.cs @ 0:f990fcb411a9
Копия текущей версии из github
author | cin |
---|---|
date | Thu, 27 Mar 2014 21:46:09 +0400 (2014-03-27) |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/HowTo/DataAccess/Update.cs Thu Mar 27 21:46:09 2014 +0400 @@ -0,0 +1,76 @@ +using System; + +using NUnit.Framework; + +using BLToolkit.Data; +using BLToolkit.DataAccess; +using BLToolkit.Mapping; + +namespace HowTo.DataAccess +{ + [TestFixture] + public class Update + { + int _id; + + [TestFixtureSetUp] + public void Insert() + { + using (DbManager db = new DbManager()) + { + _id = db + .SetCommand(@" + INSERT INTO Person ( + FirstName, LastName, Gender + ) VALUES ( + @FirstName, @LastName, @Gender + ) + SELECT Cast(SCOPE_IDENTITY() as int)", + db.Parameter("@FirstName", "Crazy"), + db.Parameter("@LastName", "Frog"), + db.Parameter("@Gender", Map.EnumToValue(Gender.Unknown))) + .ExecuteScalar<int>(); + } + } + + [Test] + public void Test1() + { + /*[a]*/SprocQuery<Person> query = new SprocQuery<Person>()/*[/a]*/; + + Person person = query.SelectByKey(_id); + + person.Gender = Gender.Other; + + query./*[a]*/Update(person)/*[/a]*/; + } + + [Test] + public void Test2() + { + using (DbManager db = new DbManager()) + { + /*[a]*/SprocQuery<Person> query = new SprocQuery<Person>()/*[/a]*/; + + Person person = query.SelectByKey(db, _id); + + person.Gender = Gender.Other; + + query./*[a]*/Update(db, person)/*[/a]*/; + } + } + + [TestFixtureTearDown] + public void Delete() + { + using (DbManager db = new DbManager()) + { + db + .SetCommand("DELETE FROM Person WHERE PersonID = @id", + db.Parameter("@id", _id)) + .ExecuteNonQuery(); + } + } + } +} +