Linq合并不同站点的结果集怎么操作?

柠檬片-味道 2015-05-06 08:21:46
有两个Oracle数据库,分别存储student表和class表,要联接两张表查询,如select s.name,c.name from student s left outer join class c on s.classid=c.id where s.hobby like '%篮球%' and c.department like '%计算机%';现在把这条sql分解成两条,分表到对应的数据库去执行然后合并:

string sql1 = "select classid,name from student where hobby like '%篮球%'";
string sql2 = "select id,name from class where department like '%计算机%'";
DataSet dataset = new DataSet();
Dictionary<string, string[]> dict = new Dictionary<string, string[]>();
dict.Add("student", new string[] { "Data Source=172.168.1.1/ORCL;User ID=user1;Password=123", sql1 });
dict.Add("class", new string[] { "Data Source=172.168.1.2/ORCL;User ID=user2;Password=123", sql2 });
var tables = (from x in dict.AsParallel() select Query(x)).ToList();
Dictionary<string, DataTable> dict1 = new Dictionary<string, DataTable>();
for (int i = 0; i < tables.Count; i++)
{
dict1.Add(tables[i].TableName, tables[i]);
}
var result = from s in dict1["student"].AsEnumerable()
join c in dict1["class"].AsEnumerable()
on s["classid"] equals c["id"]
select new
{
studentname = s["name"],
classname = c["name"]
};

static DataTable Query(KeyValuePair<string, string[]> dict)
{
string host = dict.Value[0];
string sql = dict.Value[1];
using (OracleConnection conn = new OracleConnection(host))
{
OracleDataAdapter da = new OracleDataAdapter(sql, conn);
conn.Open();
DataSet ds = new DataSet();
da.Fill(ds);
DataTable table = ds.Tables[0];
table.TableName = dict.Key;
return table;
}
}


合并时,对查询出来的结果集联接,字段的类型我并不知道,该怎么获取?合并的linq怎么写?还有个问题,由于是left out join,按照我写的方法分别去数据库中查询再合并,结果感觉会不对把?
...全文
149 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
柠檬片-味道 2015-05-07
  • 打赏
  • 举报
回复
引用 2 楼 caozhy 的回复:
你的代码可以,但是是全部取出,在内存中查询的。
合并的linq语句中取出来的字段需要转换类型,怎么获得呢?
threenewbee 2015-05-06
  • 打赏
  • 举报
回复
你的代码可以,但是是全部取出,在内存中查询的。
柠檬片-味道 2015-05-06
  • 打赏
  • 举报
回复
顶上去顶上去
内容概要:本文档聚焦于基于Peng-Robinson状态方程的化工热力学计算研究,系统介绍了利用Matlab代码实现纯组分及多组分系统的压缩因子(z因子)和逸度系数的计算方法,并进一步拓展至泡点压力与露点压力的数值求解。资源涵盖了从状态方程推导、非线性方程求根、相平衡条件判断到迭代算法实现的完整技术路线,提供了可运行的Matlab程序代码,有助于深入理解实际工程中物性参数的计算原理与实现过程; 适合人群:具备化工热力学基础知识和一定Matlab编程能力的高校学生、科研人员及工程技术人员,尤其适合从事过程系统模拟、油气田开发、精馏设计及相关领域研究的专业人士; 使用场景及目标:① 掌握Peng-Robinson方程在真实气体物性计算中的应用;② 实现多组分混合体系的相平衡计算与泡/露点预测;③ 为Aspen Plus等商用流程模拟软件提供底层算法验证与教学参考;④ 支持科研论文复现、课程设计、毕业设计及工业过程优化中的热力学数据支撑需求; 阅读建议:建议读者结合经典化工热力学教材同步学习,重点理解立方型状态方程的根判别、迭代收敛策略与相平衡准则的数学表达,动手调试并运行所提供的Matlab代码以掌握算法细节,还可将其扩展应用于其他状态方程(如SRK、vdW)的对比分析研究。

111,130

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Creator Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧