(一)Linq左连接案例分析
有如下两个DataTable:localDt和schemaDt
要实现这两个DataTable的左连接,得到如下效果:
分析一:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
var temp1 = (from schema in schemaDt.AsEnumerable()
join local in localDt.AsEnumerable()
on schema.Field<string>("name") equals local.Field<string>("sql_name")
into tempTable
from item in tempTable.DefaultIfEmpty<DataRow>()
select item).ToList();
分析二
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
var temp2 = (from local in localDt.AsEnumerable()
join schema in schemaDt.AsEnumerable()
on local.Field<string>("sql_name") equals schema.Field<string>("name")
into tempTable
from item in tempTable.DefaultIfEmpty()
select item).ToList();
分析三:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
代码var temp3 = (from schema in schemaDt.AsEnumerable() join local in localDt.AsEnumerable() on schema.Field<string>("name") equals local.Field<string>("sql_name") into tempTable from item in tempTable.DefaultIfEmpty<DataRow>(localDt.NewRow()) select item).ToList();
分析四:
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
代码var temp4 = (from schema in schemaDt.AsEnumerable() join local in localDt.AsEnumerable() on schema.Field<string>("name") equals local.Field<string>("sql_name") into tempTable from item in tempTable.DefaultIfEmpty<DataRow>(schemaDt.NewRow()) select item).ToList();