view HowTo/DataAccess/ExecuteList.cs @ 5:f7d63a092920

Исправлено условие Where в тех случаях, когда репозитарий не является генериком
author cin
date Tue, 10 Mar 2015 16:02:11 +0300
parents f990fcb411a9
children
line wrap: on
line source

using System;
using System.Collections;
using System.Collections.Generic;

using NUnit.Framework;

using BLToolkit.DataAccess;

namespace HowTo.DataAccess
{
	[TestFixture]
	public class ExecuteList
	{
		public abstract class /*[a]*/PersonAccessor/*[/a]*/ : /*[a]*/DataAccessor/*[/a]*/
		{
			// This method reads a list of Person objects.
			//
			[ActionName("SelectAll")]
			public abstract /*[a]*/List<Person>/*[/a]*/ GetPersonList1();

			// Here we help the method to get object type information.
			// /*[a]*/ObjectTypeAttribute/*[/a]*/ can be applied to the class itself.
			// In this case there is no need to specify object type for each method.
			// Another way to specify object type is a generic parameter
			// of the DataAccessor<T> class.
			//
			[SqlQuery("SELECT * FROM Person")]
			[/*[a]*/ObjectType(typeof(Person))/*[/a]*/]
			public abstract /*[a]*/ArrayList/*[/a]*/ GetPersonList2();

			// This method reads a list of scalar values.
			//
			[SqlQuery("SELECT PersonID FROM Person")]
			public abstract /*[a]*/List<int>/*[/a]*/ GetPersonIDList();
		}

		[Test]
		public void Test()
		{
			PersonAccessor pa = DataAccessor.CreateInstance<PersonAccessor>();

			// ExecuteList.
			//
			IList list;
			
			list = pa.GetPersonList1();
			list = pa.GetPersonList2();

			foreach (Person p in list)
				Console.WriteLine("{0}: {1} {2}", p.ID, p.FirstName, p.LastName);

			// ExecuteScalarList.
			//
			List<int> slist = pa.GetPersonIDList();

			foreach (int id in slist)
				Console.WriteLine("{0}", id);
		}
	}
}