8,497
社区成员
发帖
与我相关
我的任务
分享
//源sql(应用中复杂的sql包含十多张表)
string sql = "Select neflow.id,ne.depart from materialneedflow neflow left outer join materialneed ne on ne.id=neflow.applyid where ne.id=1 and neflow.id=1";
//解析成两条sql,分别去对应的站点执行
string sql11 = "select id,applyid from materialneedflow where id=1";
string sql12 = "select id,depart from materialneed where id=1";
DataSet dataset = new DataSet();
Dictionary<string, string[]> dict = new Dictionary<string, string[]>();
dict.Add("materialneedflow", new string[] { "Data Source=202.193.75.136/ORCL;User ID=site4;Password=123456", sql11 });
dict.Add("materialneed", new string[] { "Data Source=202.193.74.48/ORCL;User ID=site4;Password=123456", sql12 });
//并行地到两个站点去执行,问题1:并行方面能不能修改默认配置呢?
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]);
}
//对查出来的两个结果集合并;问题2:这里字段我都转换了类型,但是要写成一个通用模块的话,希望能从Oracle数据库(用的Oracle)中获取类型自动转换c#中类型,该怎么实现啊???
var result = from neflow in dict1["materialneedflow"].AsEnumerable()
join ne in dict1["materialneed"].AsEnumerable()
on Convert.ToDecimal(IsDBNull(neflow["applyid"])) equals Convert.ToDecimal(ne["id"])
select new
{
status = Convert.ToDecimal(neflow["id"]),
orderdate = Convert.ToDecimal(IsDBNull(ne["depart"]))
};
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;
}
}
public static object IsDBNull(object value)
{
if (value == DBNull.Value)
{
return null;
}
else
{
return value;
}
}
问题1:并行方面能不能修改默认配置呢?var dic = (from ConnectionStringSettings c in ConfigurationManager.ConnectionStrings
select c).ToDictionary(c => c.Name, c => c.ConnectionString);
至于第二个问题,编程中直接根据业务实体进行查询就行了,不要耗费过多精力去搞什么“通用转换”。例如这里
http://bbs.csdn.net/topics/391025696
所述的方法就是一个通用的SQLHelper。一个SQLHelper只是工具,它方便于你直接了当地写一行 result =...... 那样的查询语句,就可以了。在 SQlHelper 之中没有必要自身过多写代码去执行什么“转换为c#对象”问题。public static DataTable MyQuery(string DbConnection)
{
..........
}
并且你的数据库的连接串保存在这样的集合里List<string> Connections
那么你可以这样写并发查询语句var result = (from conn in Connections.AsParallel() select MyQuery(conn)).ToArray();
得到了DataTable的数组之后,你可以使用DataTable内置的合并方法将数据合并。