Mercurial > pub > bltoolkit
comparison HowTo/Data/UpdateObject.cs @ 0:f990fcb411a9
Копия текущей версии из github
| author | cin |
|---|---|
| date | Thu, 27 Mar 2014 21:46:09 +0400 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| -1:000000000000 | 0:f990fcb411a9 |
|---|---|
| 1 using System; | |
| 2 using System.Collections.Generic; | |
| 3 | |
| 4 using NUnit.Framework; | |
| 5 | |
| 6 using BLToolkit.Data; | |
| 7 using BLToolkit.Mapping; | |
| 8 using BLToolkit.Reflection; | |
| 9 | |
| 10 namespace HowTo.Data | |
| 11 { | |
| 12 [TestFixture] | |
| 13 public class UpdateObject | |
| 14 { | |
| 15 public enum Gender | |
| 16 { | |
| 17 [MapValue("F")] Female, | |
| 18 [MapValue("M")] Male, | |
| 19 [MapValue("U")] Unknown, | |
| 20 [MapValue("O")] Other | |
| 21 } | |
| 22 | |
| 23 public abstract class Person | |
| 24 { | |
| 25 [MapField("PersonID")] | |
| 26 public abstract int ID { get; } | |
| 27 | |
| 28 public abstract string LastName { get; set; } | |
| 29 public abstract string FirstName { get; set; } | |
| 30 public abstract string MiddleName { get; set; } | |
| 31 public abstract Gender Gender { get; set; } | |
| 32 } | |
| 33 | |
| 34 int InsertPerson(Person person) | |
| 35 { | |
| 36 using (DbManager db = new DbManager()) | |
| 37 { | |
| 38 return db | |
| 39 .SetCommand(@" | |
| 40 INSERT INTO Person | |
| 41 ( LastName, FirstName, MiddleName, Gender) | |
| 42 VALUES | |
| 43 (@LastName, @FirstName, @MiddleName, @Gender) | |
| 44 | |
| 45 SELECT Cast(SCOPE_IDENTITY() as int)", | |
| 46 db.CreateParameters(person)) | |
| 47 .ExecuteScalar<int>(); | |
| 48 } | |
| 49 } | |
| 50 | |
| 51 Person GetPersonByID(int id) | |
| 52 { | |
| 53 using (DbManager db = new DbManager()) | |
| 54 { | |
| 55 return db | |
| 56 .SetCommand("SELECT * FROM Person WHERE PersonID = @id", | |
| 57 db.Parameter("@id", id)) | |
| 58 .ExecuteObject<Person>(); | |
| 59 } | |
| 60 } | |
| 61 | |
| 62 void UpdatePerson(Person person) | |
| 63 { | |
| 64 using (DbManager db = new DbManager()) | |
| 65 { | |
| 66 db | |
| 67 .SetCommand(@" | |
| 68 UPDATE | |
| 69 Person | |
| 70 SET | |
| 71 LastName = @LastName, | |
| 72 FirstName = @FirstName, | |
| 73 MiddleName = @MiddleName, | |
| 74 Gender = @Gender | |
| 75 WHERE | |
| 76 PersonID = @PersonID", | |
| 77 db.CreateParameters(person)) | |
| 78 .ExecuteNonQuery(); | |
| 79 } | |
| 80 } | |
| 81 | |
| 82 void DeletePerson(int id) | |
| 83 { | |
| 84 using (DbManager db = new DbManager()) | |
| 85 { | |
| 86 db | |
| 87 .SetCommand("DELETE FROM Person WHERE PersonID = @id", | |
| 88 db.Parameter("@id", id)) | |
| 89 .ExecuteNonQuery(); | |
| 90 } | |
| 91 } | |
| 92 | |
| 93 [Test] | |
| 94 public void Test() | |
| 95 { | |
| 96 // Insert. | |
| 97 // | |
| 98 Person person = TypeAccessor<Person>.CreateInstanceEx(); | |
| 99 | |
| 100 person.FirstName = "Crazy"; | |
| 101 person.LastName = "Frog"; | |
| 102 person.Gender = Gender.Unknown; | |
| 103 | |
| 104 int id = InsertPerson(person); | |
| 105 | |
| 106 person = GetPersonByID(id); | |
| 107 | |
| 108 TypeAccessor.WriteConsole(person); | |
| 109 Assert.IsNotNull(person); | |
| 110 | |
| 111 // Update. | |
| 112 // | |
| 113 person.Gender = Gender.Other; | |
| 114 | |
| 115 UpdatePerson(person); | |
| 116 | |
| 117 person = GetPersonByID(id); | |
| 118 | |
| 119 TypeAccessor.WriteConsole(person); | |
| 120 Assert.AreEqual(Gender.Other, person.Gender); | |
| 121 | |
| 122 // Delete. | |
| 123 // | |
| 124 DeletePerson(id); | |
| 125 | |
| 126 person = GetPersonByID(id); | |
| 127 | |
| 128 Assert.IsNull(person); | |
| 129 } | |
| 130 } | |
| 131 } | |
| 132 |
