【C#】LINQ

语言集成查询LINQ是一系列直接将查询功能集成到C#语言的技术统称。

对编写查询语句的开发者来说,LINQ最明显的“语言集成”部分就是查询表达式。

查询表达式采用声明性查询语法编写而成。

使用查询语法可以用最少的语言对数据进行筛选、排序和分组。

完整的查询操作包括创建数据源、定义查询表达式和执行查询

int[] scores = new int[] { 10, 30, 40, 80, 90, 98 };
IEnumerable scoreQuery = 
from score in scores   //指定数据源           
where score > 80    //应用筛选器                                 
select score;     //返回元素的类型                                
foreach (int i in scoreQuery)    //get data        
{
    Console.Write(i + " ");    //return each item
}
//output:90 98

LINQ 数据源是支持泛型 IEnumerable<T> 接口或从中继承的接口的任意对象。

延迟查询:查询变量本身从不保存查询结果,因此可以根据需要随意执行查询。 例如,可以通过一个单独的应用程序持续更新数据库。 在应用程序中,可以创建一个检索最新数据的查询,并可以按某一时间间隔反复执行该查询以便每次检索不同的结果。

要强制立即执行查询并缓存其结果,可调用 ToList() 或 ToArray() 方法,或紧跟一个 foreach 循环。

            IList<int> scoQuery = (from sco in scores
                                  where sco % 2 == 0
                                  select sco).ToList();
            IEnumerable scoQuery2 = (from sco in scores
                             where sco % 2 == 0 && sco > 80
                             select sco).ToArray();
        /// <summary>
        /// 获取存储区信息
        /// </summary>
        /// <returns></returns>
        public DataResult<List<StorageAreaModel>> InitStorageArea()
        {
            DataResult<List<StorageAreaModel>> result = new DataResult<List<StorageAreaModel>>();
            try
            {
                var data = dataAccess.GetStorageAreas();
                result.Data = (from q in data.AsEnumerable()
                               select new StorageAreaModel
                               {
                                   ID=q.Field<string>("ID"),
                                   SlaveAddress=q.Field<Int32>("SlaveAddress"),
                                   FunctionCode=q.Field<string>("FunctionCode"),
                                   StartAddress=q.Field<Int32>("StartAddress"),
                                   Length=q.Field<Int32>("Length")
                               }).ToList();
            }
            catch (Exception ex)
            {

                result.Message=ex.Message;
            }
            return result;
        }

        /// <summary>
        /// 获取设备信息
        /// </summary>
        /// <returns></returns>
        public DataResult<List<DeviceModel>> GetDevices()
        {
            DataResult<List<DeviceModel>> result = new DataResult<List<DeviceModel>>();
            try
            {
                var devices = dataAccess.GetDevices();

                List<DeviceModel> deviceModels = new List<DeviceModel>();
                foreach (var device in devices.AsEnumerable())
                {
                    DeviceModel deviceModel = new DeviceModel();
                    deviceModel.DeviceID = device.Field<Int32>("DeviceID");
                    deviceModel.DeviceName = device.Field<string>("DeviceName");
                    deviceModels.Add(deviceModel);
                }
            }
            catch (Exception ex)
            {

                result.Message=ex.Message;
            }

            return result;
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值