xml传参

前端调用后端方法时要传递多个参数,在前端js中拼接xml形式的字符串:

复制代码
 1 var args = "<?xml version='1.0' encoding='utf-8' ?>";
 2 args += "<Bill>";
 3 for (var i = 0; i < dataChange.length; i++) {    
 4     if (dataChange[i].bghsl != undefined) {
 5         if (dataChange[i].gcsl != undefined)
 6             args += "<Item PrimaryKey = '" + data.items[i].data.gxid + "' SSBM = '" + data.items[i].data.ssbm + "' BillCode = '" + data.items[i].data.qdbh + "' ProCount = '" + dataChange[i].gcsl + "' />";
 7         else
 8             args += "<Item PrimaryKey = '" + data.items[i].data.gxid + "' SSBM = '" + data.items[i].data.ssbm + "' BillCode = '" + data.items[i].data.qdbh + "' ProCount = '" + 0 + "' />";        
 9     }
10 }
11 args += "</Bill>";
复制代码

后端接收参数并解析:

复制代码
 1 protected override string UpdateProCount(string strXml)
 2 {
 3     XmlDocument doc = new XmlDocument();
 4     doc.LoadXml(strXml);
 5     XmlElement root = doc.DocumentElement;
 6 
 7     StringBuilder strSql = new StringBuilder();
 8     StringBuilder strqd = new StringBuilder();
 9     foreach (XmlElement item in root.ChildNodes)
10     {
11         strSql.AppendFormat("update T_JJJ_JGBWQDGX set F_GCSL={0},F_BGHSL = isnull(F_BGSL,0) + {0},F_BGHJE = (isnull(F_BGSL,0) + {0}) * F_BGHDJ ", item.GetAttribute("ProCount"));
12         strSql.AppendFormat("where F_ID = {0};", item.GetAttribute("PrimaryKey"));
13         strqd.AppendFormat("'{0}',", item.GetAttribute("BillCode"));
14     }
15     int resault = GSqlDataAccess.ExecuteNonQuery("default", strSql.ToString(), null);
16     if (resault == 0)
17         return "保存失败!";
18     else
19     {
20         string fid = root.FirstChild.Attributes["PrimaryKey"].Value;
21         strSql.Clear();
22         string tmp = strqd.ToString();
23         strSql.Append("declare @BDBH number(19,0);");
24         strSql.AppendFormat("select @BDBH = F_BDBH from T_JJJ_SGGCLQDFJ where F_ID = (select F_SGGCLQDFJ_ID from T_JJJ_JGBWQDGX where F_ID = {0});", fid);
25         strSql.Append("select sum(F_GCSL) as CountSum,F_QDBH,F_BDBH from T_JJJ_SGGCLQDFJ ");
26         strSql.Append("inner join T_JJJ_JGBWQDGX on T_JJJ_SGGCLQDFJ.F_ID = T_JJJ_JGBWQDGX.F_SGGCLQDFJ_ID ");
27         strSql.AppendFormat("where T_JJJ_SGGCLQDFJ.F_BDBH = @BDBH and F_QDBH in {0} group by F_QDBH,F_BDBH ", "(" + tmp.Substring(0, tmp.Length - 1) + ")");
28         IDataReader reader = GSqlDataAccess.SelectReader("default", strSql.ToString(), null);
29         strSql.Clear();
30         while (reader.Read())
31         {
32             strSql.AppendFormat("update T_JJJ_SGHTGCLQD set F_HLSL = {0}, ", reader["CountSum"].ToString() == "" ? "0" : reader["CountSum"].ToString());
33             strSql.AppendFormat("F_HLJE = {0} * (isnull(F_HTDJ,F_BGHDJ)) ", reader["CountSum"].ToString() == "" ? "0" : reader["CountSum"].ToString());
34             strSql.AppendFormat("where F_CODE = '{0}' and F_SSBM = {1};", reader["F_QDBH"].ToString(), reader["F_BDBH"].ToString());
35         }
36         reader.Dispose();
37         resault = GSqlDataAccess.ExecuteNonQuery("default", strSql.ToString(), null);
38         if (resault > 0)
39 
40             return "保存成功!";
41 
42         else
43             return "保存失败!";
44     }
45 }
复制代码

 

posted @   wuln  阅读(937)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示