语言集成查询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;
}