ListHelper

这篇博客介绍了一个名为ListHelper的工具类,它利用Lambda表达式和Expression树简化了从SqlDataReader读取数据并转换为List的过程。通过提供更方便的方法,使得在处理数据库查询结果时的代码更加简洁和高效。
摘要由CSDN通过智能技术生成

using System;
using System.Reflection;
using System.Data.SqlClient;
using System.Linq;
using System.Linq.Expressions;
using System.Collections.Generic;

namespace xxxxxxxxxxxx
{
    public class ListHelper<T>
    {
        public List<T> CreateList(SqlDataReader reader)
        {
            Func<SqlDataReader, T> readRow = this.GetReader(reader);

            var results = new List<T>();

            while (reader.Read())
                results.Add(readRow(reader));

            return results;
        }
        public List<T> SortList(List<T> listToSort, string propertyName, bool ascending)
        {
            // verify that the propertyName is valid
            var propertyNames = typeof(T).GetProperties().ToList().Select(p => p.Name).ToList();
            if (!propertyNames.Contains(propertyName))
                throw new ArgumentOutOfRangeException("There is no property named: " + propertyName);

            var paramExpression = Expression.Parameter(typeof(T), "item");
            var propertyExpression = Expression.Convert(Expression.Property(paramExpression, propertyName), typeof(object));
            var lambdaExpression = Expression.Lambda<Func<T, object>>(propertyExpression, paramExpression);

            if (ascending)
                return listToSort.AsQueryable().OrderBy(lambdaExpression).ToList();
            else
                return listToSort.AsQueryable().OrderByDescending(lambdaExpression).ToList();
        }

        private Func<SqlDataReader, T> GetReader(SqlDataReader rea
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值