public void InitM() { double temp = .0; using (OleDbConnection connection = new OleDbConnection(ConnectionString)) { connection.Open(); using (OleDbCommand Command = connection.CreateCommand()) { Command.CommandText = "Select DKBH,PZYDMJ,TDDJMJ,DYMJ,YDZMJ,WJPZYDMJ,JZZMJ,JZZDMJ,WPZJZMJ,WPZJZZDMJ,SFWYCYPT,CYPTMC,TDSYQK,YKFTDMJ,WKFTDMJ from GYYD"; using (var reader = Command.ExecuteReader()) { string DKBH = string.Empty; while (reader.Read()) { DKBH = reader[0].ToString().Trim(); if (!string.IsNullOrEmpty(DKBH) && !AreaDict.ContainsKey(DKBH)) { AreaDict.Add(DKBH, new Union() { AreaBase = new AreaBase() { PZYDMJ = double.TryParse(reader[1].ToString(), out temp) ? temp : 0, TDDJMJ = double.TryParse(reader[2].ToString(), out temp) ? temp : 0, DYMJ = double.TryParse(reader[3].ToString(), out temp) ? temp : 0 }, AreaOne = new AreaOne() { YDZMJ = double.TryParse(reader[4].ToString(), out temp) ? temp : 0, WJPZYDMJ = double.TryParse(reader[5].ToString(), out temp) ? temp : 0, JZZMJ = double.TryParse(reader[6].ToString(), out temp) ? temp : 0, JZZDMJ = double.TryParse(reader[7].ToString(), out temp) ? temp : 0, WPZJZMJ = double.TryParse(reader[8].ToString(), out temp) ? temp : 0, WPZJZZDMJ = double.TryParse(reader[9].ToString(), out temp) ? temp : 0, SFWYCYPT = reader[10].ToString() == "是" ? true : false, CYPTMC = reader[11].ToString(), TDSYQK = reader[12].ToString(), YKFTDMJ = double.TryParse(reader[13].ToString(), out temp) ? temp : 0, WKFTDMJ = double.TryParse(reader[14].ToString(), out temp) ? temp : 0 } }); } } } Command.CommandText = "Select DKBH,SJYT from TDSJYTJG"; using (var reader = Command.ExecuteReader()) { string DKBH = string.Empty; string SJYT = string.Empty; while (reader.Read()) { DKBH = reader[0].ToString(); SJYT = reader[1].ToString(); if (!string.IsNullOrEmpty(DKBH) && !string.IsNullOrEmpty(SJYT)) { if (!WayDict.ContainsKey(DKBH)) { WayDict.Add(DKBH, SJYT); } else { WayDict[DKBH] = WayDict[DKBH] + "," + SJYT; } } } } Command.CommandText = "Select QYBH,SFGXQY,HYDM,XZJDMC,SFGSQY,CYRS,LJGDZCTZ,YDL2012,YDL2013,YDL2014,GSRKSS2012,GSRKSS2013,GSRKSS2014,DSRKSS2012,DSRKSS2013,DSRKSS2014,ZYYSR2012,ZYYSR2013,ZYYSR2014,QYMC from YDDW"; using (var reader = Command.ExecuteReader()) { string QYBH = string.Empty; while (reader.Read()) { QYBH = reader[0].ToString(); if (!string.IsNullOrEmpty(QYBH) && !FacDict.ContainsKey(QYBH)) { try { double val = 0.0; FacDict.Add(QYBH, new MergeBase() { SFGXQY = reader[1].ToString() == "是" ? true : false, HYDM = reader[2].ToString(), XZJDMC = reader[3].ToString(), SFGSQY = reader[4].ToString() == "是" ? true : false, CYRS = int.Parse(reader[5].ToString()), LJGDZCTZ = double.TryParse(reader[6].ToString(), out val)?val:.0, YDL2012 = double.TryParse(reader[7].ToString(), out val)?val:.0, YDL2013 = double.TryParse(reader[8].ToString(), out val)?val:.0, YDL2014 = double.TryParse(reader[9].ToString(), out val)?val:.0, GSRKSS2012 = double.TryParse(reader[10].ToString(), out val)?val:.0, GSRKSS2013 = double.TryParse(reader[11].ToString(), out val)?val:.0, GSRKSS2014 = double.TryParse(reader[12].ToString(), out val)?val:.0, DSRKSS2012 = double.TryParse(reader[13].ToString(), out val)?val:.0, DSRKSS2013 = double.TryParse(reader[14].ToString(), out val)?val:.0, DSRKSS2014 = double.TryParse(reader[15].ToString(), out val)?val:.0, ZYYSR2012 = double.TryParse(reader[16].ToString(), out val)?val:.0, ZYYSR2013 = double.TryParse(reader[17].ToString(), out val)?val:.0, ZYYSR2014 = double.TryParse(reader[18].ToString(), out val)?val:.0 }); var qymc = reader[19].ToString().Trim(); if (!string.IsNullOrEmpty(qymc)) { YDDWDict.Add(QYBH, qymc); } Console.WriteLine("成功"); } catch (Exception ex) { Console.WriteLine(ex.ToString()); } } } } Command.CommandText = "Select DKBH,COUNT(*) from GYYD_YDDW Group By DKBH"; using (var reader = Command.ExecuteReader()) { string DKBH = string.Empty; int val = 0; while (reader.Read()) { DKBH = reader[0].ToString(); if (!string.IsNullOrEmpty(DKBH) && !NumberDict.ContainsKey(DKBH)) { NumberDict.Add(DKBH, int.TryParse(reader[1].ToString(), out val) ? val : 0); } } } } connection.Close(); } }
public void Working() { InitM(); using (OleDbConnection Connection = new OleDbConnection(ConnectionString)) { Connection.Open(); using (OleDbCommand Command = Connection.CreateCommand()) { #region 更新批准用地面积 土地登记面积 抵押面积 Command.CommandText = "UPDATE GYYD_YDDW SET PZYDMJ=NULL,TDDJMJ=NULL,DYMJ=NULL where 地块所有人 IS NULL"; try { Command.ExecuteNonQuery(); } catch (Exception ex) { Console.WriteLine(ex.ToString()); } foreach (string DKBH in AreaDict.Keys) { var values = AreaDict[DKBH].AreaBase; if (values != null) { Command.CommandText = string.Format("UPDATE GYYD_YDDW SET PZYDMJ={0},TDDJMJ={1},DYMJ={2} Where 地块所有人 IS NOT NULL AND DKBH='{3}'", values.PZYDMJ, values.TDDJMJ, values.DYMJ, DKBH); try { Command.ExecuteNonQuery(); } catch (Exception ex) { Console.WriteLine(ex.ToString()); } } } #endregion string commandText = string.Empty; foreach (var item in GYDWList) { commandText = "UPDATE GYYD_YDDW SET"; if (WayDict.ContainsKey(item.DKBH)) { commandText += " SJYT='" + WayDict[item.DKBH] + "',"; } AreaOne one = null; if (AreaDict.ContainsKey(item.DKBH)) { one = AreaDict[item.DKBH].AreaOne; var percent = item.JZMJ / one.JZZMJ; if (double.IsNaN(percent)) { if (NumberDict.ContainsKey(item.DKBH)) { percent = ((double)1) / ((double)NumberDict[item.DKBH]); } else { percent = .0; } } one = one * percent; //commandText += string.Format(" YDZMJ={0},WJPZYDMJ={1},JZZMJ={2}", one.YDZMJ,one.WJPZYDMJ,one.JZZMJ); commandText += string.Format(" YDZMJ={0},WJPZYDMJ={1},JZZDMJ={2},WPZJZMJ={3},WPZJZZDMJ={4},JZZMJ={5},SFWYCYPT='{6}',CYPTMC='{7}',TDSYQK='{8}',YKFTDMJ={9},WKFTDMJ={10},", one.YDZMJ, one.WJPZYDMJ, one.JZZDMJ, one.WPZJZMJ, one.WPZJZZDMJ, one.JZZMJ, one.SFWYCYPT ? "是" : "否", one.CYPTMC, one.TDSYQK, one.YKFTDMJ, one.WKFTDMJ); } if (FacDict.ContainsKey(item.QYBH)) { var fac = FacDict[item.QYBH]; TempData body = null; if (TempDict.ContainsKey(item.QYBH)) { body = TempDict[item.QYBH]; if (body.merge == null) { TempDict[item.QYBH].merge = fac; } if (body.Count == 1) { fac = body.merge - body.Reduce; } else { TempDict[item.QYBH].Count--; fac = fac * item.Percent; TempDict[item.QYBH].Reduce = body.Reduce + fac; } } else { fac = fac * item.Percent; body = new TempData(); body.CurrentNumber = 0; } //commandText += string.Format(" SFGXQY='{0}',SFGSQY='{1}',CYRS={2},HYDM='{3}'", // fac.SFGXQY ? "是" : "否", fac.SFGSQY ? "是" : "否", fac.CYRS,fac.HYDM // ); commandText += string.Format(" SFGXQY='{0}',HYDM='{1}',XZQMC='{2}',SFGSQY='{3}',CYRS={4},LJGDZCTZ={5},YDL2012={6},YDL2013={7},YDL2014={8},GSRKSS2012={9},GSRKSS2013={10},GSRKSS2014={11},DSRKSS2012={12},DSRKSS2013={13},DSRKSS2014={14},ZYYSR2012={15},ZYYSR2013={16},ZYYSR2014={17},CZQYSL={18}", fac.SFGXQY ? "是" : "否", fac.HYDM, fac.XZJDMC, fac.SFGSQY ? "是" : "否", fac.CYRS, fac.LJGDZCTZ, fac.YDL2012, fac.YDL2013, fac.YDL2014, fac.GSRKSS2012, fac.GSRKSS2013, fac.GSRKSS2014, fac.DSRKSS2012, fac.DSRKSS2013, fac.DSRKSS2014, fac.ZYYSR2012, fac.ZYYSR2013, fac.ZYYSR2014, body.CZQYSL ); } commandText += string.Format(" where DKBH='{0}' AND QYBH='{1}'", item.DKBH, item.QYBH); try { Command.CommandText = commandText; Command.ExecuteNonQuery(); Console.WriteLine("成功2"); } catch (Exception ex) { Console.WriteLine(ex.ToString()); } } } Connection.Close(); } }