496 lines
		
	
	
		
			25 KiB
		
	
	
	
		
			C#
		
	
	
	
		
		
			
		
	
	
			496 lines
		
	
	
		
			25 KiB
		
	
	
	
		
			C#
		
	
	
	
|  | using BLL; | |||
|  | using System; | |||
|  | using System.Collections.Generic; | |||
|  | using System.Data; | |||
|  | using System.Data.SqlClient; | |||
|  | using System.Linq; | |||
|  | 
 | |||
|  | namespace FineUIPro.Web.JDGL.CostAnalysis | |||
|  | { | |||
|  |     public partial class EarnedValueCurve : PageBase | |||
|  |     { | |||
|  |         #region 加载 | |||
|  |         /// <summary> | |||
|  |         /// 加载页面 | |||
|  |         /// </summary> | |||
|  |         /// <param name="sender"></param> | |||
|  |         /// <param name="e"></param> | |||
|  |         protected void Page_Load(object sender, EventArgs e) | |||
|  |         { | |||
|  |             if (!IsPostBack) | |||
|  |             { | |||
|  |                 BLL.UnitService.InitUnitDropDownList(this.drpUnit, this.CurrUser.LoginProjectId, true); | |||
|  |                 BindChart(); | |||
|  |                 InitTreeMenu(); | |||
|  |             } | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region 加载 | |||
|  |         /// <summary> | |||
|  |         /// 加载树 | |||
|  |         /// </summary> | |||
|  |         private void InitTreeMenu() | |||
|  |         { | |||
|  |             this.trWBS.Nodes.Clear(); | |||
|  |             this.trWBS.ShowBorder = false; | |||
|  |             this.trWBS.ShowHeader = false; | |||
|  |             this.trWBS.EnableIcons = true; | |||
|  |             this.trWBS.AutoScroll = true; | |||
|  |             var installations = from x in Funs.DB.Project_Installation where x.ProjectId == this.CurrUser.LoginProjectId && x.SuperInstallationId == "0" orderby x.InstallationCode select x; | |||
|  |             foreach (var installation in installations) | |||
|  |             { | |||
|  |                 TreeNode rootNode = new TreeNode(); | |||
|  |                 rootNode.Text = installation.InstallationName; | |||
|  |                 rootNode.NodeID = installation.InstallationId; | |||
|  |                 rootNode.CommandName = "installation"; | |||
|  |                 rootNode.CommandArgument = installation.UnitId; | |||
|  |                 rootNode.ToolTip = installation.InstallationCode; | |||
|  |                 rootNode.EnableClickEvent = true; | |||
|  |                 if (installation.InstallationName != "总图") | |||
|  |                 { | |||
|  |                     rootNode.Expanded = true; | |||
|  |                 } | |||
|  |                 else | |||
|  |                 { | |||
|  |                     rootNode.EnableExpandEvent = true; | |||
|  |                 } | |||
|  |                 this.trWBS.Nodes.Add(rootNode); | |||
|  |                 var installation1s = from x in Funs.DB.Project_Installation | |||
|  |                                      where x.SuperInstallationId == installation.InstallationId | |||
|  |                                      orderby x.InstallationCode | |||
|  |                                      select x; | |||
|  |                 if (installation1s.Count() > 0) | |||
|  |                 { | |||
|  |                     foreach (var installation1 in installation1s) | |||
|  |                     { | |||
|  |                         TreeNode newNode = new TreeNode(); | |||
|  |                         newNode.Text = installation1.InstallationName; | |||
|  |                         newNode.NodeID = installation1.InstallationId; | |||
|  |                         newNode.CommandName = "installation"; | |||
|  |                         newNode.CommandArgument = installation1.Weights == null ? null : installation1.Weights.ToString(); | |||
|  |                         newNode.ToolTip = installation1.InstallationCode; | |||
|  |                         newNode.EnableClickEvent = true; | |||
|  |                         newNode.Expanded = true; | |||
|  |                         rootNode.Nodes.Add(newNode); | |||
|  |                         var installation2s = from x in Funs.DB.Project_Installation | |||
|  |                                              where x.SuperInstallationId == installation1.InstallationId | |||
|  |                                              orderby x.InstallationCode | |||
|  |                                              select x; | |||
|  |                         foreach (var installation2 in installation2s) | |||
|  |                         { | |||
|  |                             TreeNode newNode2 = new TreeNode(); | |||
|  |                             newNode2.Text = installation2.InstallationName; | |||
|  |                             newNode2.NodeID = installation2.InstallationId; | |||
|  |                             newNode2.CommandName = "installation"; | |||
|  |                             newNode2.CommandArgument = installation2.Weights == null ? null : installation2.Weights.ToString(); | |||
|  |                             newNode2.ToolTip = installation2.InstallationCode; | |||
|  |                             newNode2.EnableClickEvent = true; | |||
|  |                             newNode2.Expanded = true; | |||
|  |                             newNode.Nodes.Add(newNode2); | |||
|  |                             var cnProfessions = from x in Funs.DB.WBS_CnProfession where x.InstallationId == installation2.InstallationId orderby x.OldId select x; | |||
|  |                             foreach (var cnProfession in cnProfessions) | |||
|  |                             { | |||
|  |                                 var unitProjects = from x in Funs.DB.Wbs_UnitProject where x.CnProfessionId == cnProfession.CnProfessionId && x.IsApprove == true select x; | |||
|  |                                 if (unitProjects.Count() > 0) | |||
|  |                                 { | |||
|  |                                     TreeNode newNode3 = new TreeNode(); | |||
|  |                                     newNode3.Text = cnProfession.CnProfessionName; | |||
|  |                                     newNode3.NodeID = cnProfession.CnProfessionId; | |||
|  |                                     newNode3.CommandName = "cnProfession"; | |||
|  |                                     newNode3.CommandArgument = cnProfession.UnitId; | |||
|  |                                     newNode3.ToolTip = cnProfession.CnProfessionCode; | |||
|  |                                     newNode3.EnableExpandEvent = true; | |||
|  |                                     newNode3.EnableClickEvent = true; | |||
|  |                                     newNode2.Nodes.Add(newNode3); | |||
|  |                                     TreeNode emptyNode = new TreeNode(); | |||
|  |                                     emptyNode.Text = ""; | |||
|  |                                     emptyNode.NodeID = ""; | |||
|  |                                     newNode3.Nodes.Add(emptyNode); | |||
|  |                                 } | |||
|  |                             } | |||
|  |                         } | |||
|  |                     } | |||
|  |                 } | |||
|  |                 else | |||
|  |                 { | |||
|  |                     TreeNode emptyNode = new TreeNode(); | |||
|  |                     emptyNode.Text = ""; | |||
|  |                     emptyNode.NodeID = ""; | |||
|  |                     rootNode.Nodes.Add(emptyNode); | |||
|  |                 } | |||
|  |             } | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Tree展开事件 | |||
|  |         /// <summary> | |||
|  |         /// 树展开事件 | |||
|  |         /// </summary> | |||
|  |         /// <param name="sender"></param> | |||
|  |         /// <param name="e"></param> | |||
|  |         protected void trWBS_NodeExpand(object sender, TreeNodeEventArgs e) | |||
|  |         { | |||
|  |             BindChart(); | |||
|  |             e.Node.Nodes.Clear(); | |||
|  |             if (e.Node.CommandName == "installation")  //展开装置/单元节点 | |||
|  |             { | |||
|  |                 var installations = from x in Funs.DB.Project_Installation | |||
|  |                                     where x.SuperInstallationId == e.Node.NodeID | |||
|  |                                     orderby x.InstallationCode | |||
|  |                                     select x; | |||
|  |                 if (installations.Count() > 0) | |||
|  |                 { | |||
|  |                     foreach (var installation in installations) | |||
|  |                     { | |||
|  |                         TreeNode newNode = new TreeNode(); | |||
|  |                         newNode.Text = installation.InstallationName; | |||
|  |                         newNode.NodeID = installation.InstallationId; | |||
|  |                         newNode.CommandName = "installation"; | |||
|  |                         newNode.CommandArgument = installation.Weights == null ? null : installation.Weights.ToString(); | |||
|  |                         newNode.ToolTip = installation.InstallationCode; | |||
|  |                         newNode.EnableExpandEvent = true; | |||
|  |                         newNode.EnableClickEvent = true; | |||
|  |                         e.Node.Nodes.Add(newNode); | |||
|  |                         TreeNode emptyNode = new TreeNode(); | |||
|  |                         emptyNode.Text = ""; | |||
|  |                         emptyNode.NodeID = ""; | |||
|  |                         newNode.Nodes.Add(emptyNode); | |||
|  |                     } | |||
|  |                 } | |||
|  |                 else | |||
|  |                 { | |||
|  |                     var cnProfessions = from x in Funs.DB.WBS_CnProfession where x.InstallationId == e.Node.NodeID orderby x.OldId select x; | |||
|  |                     if (cnProfessions.Count() > 0)   //普通装置主项 | |||
|  |                     { | |||
|  |                         foreach (var cnProfession in cnProfessions) | |||
|  |                         { | |||
|  |                             var unitProjects = from x in Funs.DB.Wbs_UnitProject where x.CnProfessionId == cnProfession.CnProfessionId && x.IsApprove == true select x; | |||
|  |                             if (unitProjects.Count() > 0) | |||
|  |                             { | |||
|  |                                 TreeNode newNode = new TreeNode(); | |||
|  |                                 newNode.Text = cnProfession.CnProfessionName; | |||
|  |                                 newNode.NodeID = cnProfession.CnProfessionId; | |||
|  |                                 newNode.CommandName = "cnProfession"; | |||
|  |                                 newNode.CommandArgument = cnProfession.Weights == null ? null : cnProfession.Weights.ToString(); | |||
|  |                                 newNode.ToolTip = cnProfession.CnProfessionCode; | |||
|  |                                 newNode.EnableExpandEvent = true; | |||
|  |                                 newNode.EnableClickEvent = true; | |||
|  |                                 e.Node.Nodes.Add(newNode); | |||
|  |                                 TreeNode emptyNode = new TreeNode(); | |||
|  |                                 emptyNode.Text = ""; | |||
|  |                                 emptyNode.NodeID = ""; | |||
|  |                                 newNode.Nodes.Add(emptyNode); | |||
|  |                             } | |||
|  |                         } | |||
|  |                     } | |||
|  |                     else       //总图 | |||
|  |                     { | |||
|  |                         var unitProjects = from x in Funs.DB.Wbs_UnitProject where x.InstallationId == e.Node.NodeID && x.SuperUnitProjectId == null orderby x.SortIndex, x.UnitProjectCode select x; | |||
|  |                         foreach (var unitProject in unitProjects) | |||
|  |                         { | |||
|  |                             var wbsSets = from x in Funs.DB.Wbs_WbsSet where x.UnitProjectId == unitProject.UnitProjectId && x.IsApprove == true select x; | |||
|  |                             if (wbsSets.Count() > 0) | |||
|  |                             { | |||
|  |                                 TreeNode newNode = new TreeNode(); | |||
|  |                                 newNode.Text = unitProject.UnitProjectName; | |||
|  |                                 newNode.NodeID = unitProject.UnitProjectId; | |||
|  |                                 newNode.CommandName = "unitProject"; | |||
|  |                                 newNode.CommandArgument = unitProject.Weights == null ? null : unitProject.Weights.ToString(); | |||
|  |                                 newNode.ToolTip = unitProject.UnitProjectCode; | |||
|  |                                 newNode.EnableExpandEvent = true; | |||
|  |                                 newNode.EnableClickEvent = true; | |||
|  |                                 e.Node.Nodes.Add(newNode); | |||
|  |                                 TreeNode emptyNode = new TreeNode(); | |||
|  |                                 emptyNode.Text = ""; | |||
|  |                                 emptyNode.NodeID = ""; | |||
|  |                                 newNode.Nodes.Add(emptyNode); | |||
|  |                             } | |||
|  |                         } | |||
|  |                     } | |||
|  |                 } | |||
|  |             } | |||
|  |             else if (e.Node.CommandName == "cnProfession")   //展开专业节点 | |||
|  |             { | |||
|  |                 var unitProjects = from x in Funs.DB.Wbs_UnitProject where x.CnProfessionId == e.Node.NodeID && x.SuperUnitProjectId == null && x.IsApprove == true orderby x.SortIndex, x.UnitProjectCode select x; | |||
|  |                 foreach (var unitProject in unitProjects) | |||
|  |                 { | |||
|  |                     TreeNode newNode = new TreeNode(); | |||
|  |                     newNode.Text = unitProject.UnitProjectName; | |||
|  |                     newNode.NodeID = unitProject.UnitProjectId; | |||
|  |                     newNode.CommandName = "unitProject"; | |||
|  |                     newNode.CommandArgument = unitProject.Weights == null ? null : unitProject.Weights.ToString(); | |||
|  |                     newNode.ToolTip = unitProject.UnitProjectCode; | |||
|  |                     newNode.EnableExpandEvent = true; | |||
|  |                     newNode.EnableClickEvent = true; | |||
|  |                     e.Node.Nodes.Add(newNode); | |||
|  |                     TreeNode emptyNode = new TreeNode(); | |||
|  |                     emptyNode.Text = ""; | |||
|  |                     emptyNode.NodeID = ""; | |||
|  |                     newNode.Nodes.Add(emptyNode); | |||
|  |                 } | |||
|  |             } | |||
|  |             else if (e.Node.CommandName == "unitProject")   //展开单位工程节点 | |||
|  |             { | |||
|  |                 var childUnitProjects = from x in Funs.DB.Wbs_UnitProject where x.SuperUnitProjectId == e.Node.NodeID && x.IsApprove == true orderby x.SortIndex, x.UnitProjectCode select x; | |||
|  |                 if (childUnitProjects.Count() > 0)   //存在子单位工程 | |||
|  |                 { | |||
|  |                     foreach (var childUnitProject in childUnitProjects) | |||
|  |                     { | |||
|  |                         TreeNode newNode = new TreeNode(); | |||
|  |                         newNode.Text = childUnitProject.UnitProjectName; | |||
|  |                         newNode.NodeID = childUnitProject.UnitProjectId; | |||
|  |                         newNode.CommandName = "childUnitProject"; | |||
|  |                         newNode.CommandArgument = childUnitProject.Weights == null ? null : childUnitProject.Weights.ToString(); | |||
|  |                         newNode.ToolTip = childUnitProject.UnitProjectCode; | |||
|  |                         newNode.EnableExpandEvent = true; | |||
|  |                         newNode.EnableClickEvent = true; | |||
|  |                         e.Node.Nodes.Add(newNode); | |||
|  |                         TreeNode emptyNode = new TreeNode(); | |||
|  |                         emptyNode.Text = ""; | |||
|  |                         emptyNode.NodeID = ""; | |||
|  |                         newNode.Nodes.Add(emptyNode); | |||
|  |                     } | |||
|  |                 } | |||
|  |                 else     //不存在子单位工程,加载分部工程 | |||
|  |                 { | |||
|  |                     var wbsSet1s = from x in Funs.DB.Wbs_WbsSet where x.Flag == 1 && x.UnitProjectId == e.Node.NodeID && x.IsApprove == true && x.NoShow == null orderby x.SortIndex, x.WbsSetCode select x; | |||
|  |                     if (wbsSet1s.Count() > 0) | |||
|  |                     { | |||
|  |                         foreach (var wbsSet1 in wbsSet1s) | |||
|  |                         { | |||
|  |                             TreeNode newNode = new TreeNode(); | |||
|  |                             newNode.Text = wbsSet1.WbsSetName; | |||
|  |                             newNode.NodeID = wbsSet1.WbsSetId; | |||
|  |                             newNode.CommandName = "wbsSet"; | |||
|  |                             newNode.CommandArgument = wbsSet1.Weights == null ? null : wbsSet1.Weights.ToString(); | |||
|  |                             newNode.ToolTip = wbsSet1.WbsSetCode; | |||
|  |                             newNode.EnableExpandEvent = true; | |||
|  |                             newNode.EnableClickEvent = true; | |||
|  |                             e.Node.Nodes.Add(newNode); | |||
|  |                             var childWbsSets2 = BLL.WbsSetService.GetApproveWbsSetsBySuperWbsSetId(newNode.NodeID); | |||
|  |                             if (childWbsSets2.Count() > 0) | |||
|  |                             { | |||
|  |                                 TreeNode emptyNode = new TreeNode(); | |||
|  |                                 emptyNode.Text = ""; | |||
|  |                                 emptyNode.NodeID = ""; | |||
|  |                                 newNode.Nodes.Add(emptyNode); | |||
|  |                             } | |||
|  |                         } | |||
|  |                     } | |||
|  |                     else    //单位工程下直接是分项内容,如质量行为 | |||
|  |                     { | |||
|  |                         var wbsSet3s = from x in Funs.DB.Wbs_WbsSet where x.Flag == 3 && x.UnitProjectId == e.Node.NodeID && x.IsApprove == true && x.NoShow == null orderby x.SortIndex, x.WbsSetCode select x; | |||
|  |                         if (wbsSet3s.Count() > 0) | |||
|  |                         { | |||
|  |                             foreach (var wbsSet3 in wbsSet3s) | |||
|  |                             { | |||
|  |                                 TreeNode newNode = new TreeNode(); | |||
|  |                                 newNode.Text = wbsSet3.WbsSetName; | |||
|  |                                 newNode.NodeID = wbsSet3.WbsSetId; | |||
|  |                                 newNode.CommandName = "wbsSet"; | |||
|  |                                 newNode.CommandArgument = wbsSet3.Weights == null ? null : wbsSet3.Weights.ToString(); | |||
|  |                                 newNode.ToolTip = wbsSet3.WbsSetCode; | |||
|  |                                 newNode.EnableExpandEvent = true; | |||
|  |                                 newNode.EnableClickEvent = true; | |||
|  |                                 e.Node.Nodes.Add(newNode); | |||
|  |                                 var childWbsSets2 = BLL.WbsSetService.GetApproveWbsSetsBySuperWbsSetId(newNode.NodeID); | |||
|  |                                 if (childWbsSets2.Count() > 0) | |||
|  |                                 { | |||
|  |                                     TreeNode emptyNode = new TreeNode(); | |||
|  |                                     emptyNode.Text = ""; | |||
|  |                                     emptyNode.NodeID = ""; | |||
|  |                                     newNode.Nodes.Add(emptyNode); | |||
|  |                                 } | |||
|  |                             } | |||
|  |                         } | |||
|  |                     } | |||
|  |                 } | |||
|  |             } | |||
|  |             else if (e.Node.CommandName == "childUnitProject")   //展开子单位工程节点 | |||
|  |             { | |||
|  |                 var wbsSet1s = from x in Funs.DB.Wbs_WbsSet where x.Flag == 1 && x.UnitProjectId == e.Node.NodeID && x.IsApprove == true && x.NoShow == null orderby x.SortIndex, x.WbsSetCode select x; | |||
|  |                 foreach (var wbsSet1 in wbsSet1s) | |||
|  |                 { | |||
|  |                     TreeNode newNode = new TreeNode(); | |||
|  |                     newNode.Text = wbsSet1.WbsSetName; | |||
|  |                     newNode.NodeID = wbsSet1.WbsSetId; | |||
|  |                     newNode.CommandName = "wbsSet"; | |||
|  |                     newNode.CommandArgument = wbsSet1.Weights == null ? null : wbsSet1.Weights.ToString(); | |||
|  |                     newNode.ToolTip = wbsSet1.WbsSetCode; | |||
|  |                     newNode.EnableExpandEvent = true; | |||
|  |                     newNode.EnableClickEvent = true; | |||
|  |                     e.Node.Nodes.Add(newNode); | |||
|  |                     var childWbsSets2 = BLL.WbsSetService.GetApproveWbsSetsBySuperWbsSetId(newNode.NodeID); | |||
|  |                     if (childWbsSets2.Count() > 0) | |||
|  |                     { | |||
|  |                         TreeNode emptyNode = new TreeNode(); | |||
|  |                         emptyNode.Text = ""; | |||
|  |                         emptyNode.NodeID = ""; | |||
|  |                         newNode.Nodes.Add(emptyNode); | |||
|  |                     } | |||
|  |                 } | |||
|  |             } | |||
|  |             else if (e.Node.CommandName == "wbsSet")   //展开分部/子分部/分项/子分项工程节点 | |||
|  |             { | |||
|  |                 var childWbsSets = BLL.WbsSetService.GetApproveWbsSetsBySuperWbsSetId(e.Node.NodeID); | |||
|  |                 foreach (var wbsSet in childWbsSets) | |||
|  |                 { | |||
|  |                     TreeNode newNode = new TreeNode(); | |||
|  |                     newNode.Text = wbsSet.WbsSetName; | |||
|  |                     newNode.NodeID = wbsSet.WbsSetId; | |||
|  |                     newNode.CommandName = "wbsSet"; | |||
|  |                     newNode.CommandArgument = wbsSet.Weights == null ? null : wbsSet.Weights.ToString(); | |||
|  |                     newNode.ToolTip = wbsSet.WbsSetCode; | |||
|  |                     newNode.EnableExpandEvent = true; | |||
|  |                     newNode.EnableClickEvent = true; | |||
|  |                     e.Node.Nodes.Add(newNode); | |||
|  |                     var childWbsSets2 = BLL.WbsSetService.GetApproveWbsSetsBySuperWbsSetId(newNode.NodeID); | |||
|  |                     if (childWbsSets2.Count() > 0) | |||
|  |                     { | |||
|  |                         TreeNode emptyNode = new TreeNode(); | |||
|  |                         emptyNode.Text = ""; | |||
|  |                         emptyNode.NodeID = ""; | |||
|  |                         newNode.Nodes.Add(emptyNode); | |||
|  |                     } | |||
|  |                 } | |||
|  |             } | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region 下拉选择事件 | |||
|  |         /// <summary> | |||
|  |         /// 单位下拉选择事件 | |||
|  |         /// </summary> | |||
|  |         /// <param name="sender"></param> | |||
|  |         /// <param name="e"></param> | |||
|  |         protected void drpUnit_SelectedIndexChanged(object sender, EventArgs e) | |||
|  |         { | |||
|  |             List<string> nodeIds = new List<string>(); | |||
|  |             if (this.drpUnit.SelectedValue != BLL.Const._Null) | |||
|  |             { | |||
|  |                 foreach (var item in this.trWBS.Nodes) | |||
|  |                 { | |||
|  |                     if (item.CommandArgument == this.drpUnit.SelectedValue) | |||
|  |                     { | |||
|  |                         nodeIds.Add(item.NodeID); | |||
|  |                     } | |||
|  |                     foreach (var item1 in item.Nodes) | |||
|  |                     { | |||
|  |                         foreach (var item2 in item1.Nodes) | |||
|  |                         { | |||
|  |                             foreach (var item3 in item2.Nodes) | |||
|  |                             { | |||
|  |                                 if (item3.CommandArgument == this.drpUnit.SelectedValue) | |||
|  |                                 { | |||
|  |                                     nodeIds.Add(item3.NodeID); | |||
|  |                                 } | |||
|  |                             } | |||
|  |                         } | |||
|  |                     } | |||
|  |                 } | |||
|  |             } | |||
|  |             this.trWBS.SelectedNodeIDArray = nodeIds.ToArray(); | |||
|  |             BindChart(); | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Tree点击事件 | |||
|  |         /// <summary> | |||
|  |         /// Tree点击事件 | |||
|  |         /// </summary> | |||
|  |         /// <param name="sender"></param> | |||
|  |         /// <param name="e"></param> | |||
|  |         protected void trWBS_NodeCommand(object sender, TreeCommandEventArgs e) | |||
|  |         { | |||
|  |             BindChart(); | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region 数据绑定 | |||
|  |         /// <summary> | |||
|  |         /// 数据绑定 | |||
|  |         /// </summary> | |||
|  |         private void BindChart() | |||
|  |         { | |||
|  |             string[] nodeIds = this.trWBS.SelectedNodeIDArray; | |||
|  |             string toWbs = string.Empty; | |||
|  |             foreach (var nodeId in nodeIds) | |||
|  |             { | |||
|  |                 toWbs += nodeId + ","; | |||
|  |             } | |||
|  |             string strSql = "select distinct (cast(YEAR(Months) as varchar(4))+'.'+cast(MONTH(Months) as varchar(2))) as 月份,t.Months, (select SUM(PlanValue) from dbo.WbsDetail where Months=t.Months and CHARINDEX(ToWbs,@ToWbs)>0) as 计划值," + | |||
|  |                              "(select SUM(PlanValue) from dbo.WbsDetail where Months<=t.Months and CHARINDEX(ToWbs,@ToWbs)>0) as 计划累积值 ," + | |||
|  |                              "(select SUM(CompleteValue) from dbo.WbsDetail where Months=t.Months and CHARINDEX(ToWbs,@ToWbs)>0) as 完成值," + | |||
|  |                              "(select SUM(CompleteValue) from dbo.WbsDetail where Months<=t.Months and CHARINDEX(ToWbs,@ToWbs)>0) as 完成累积值," + | |||
|  |                              "(select SUM(RealValue) from dbo.WbsDetail where Months=t.Months and CHARINDEX(ToWbs,@ToWbs)>0) as 实耗值," + | |||
|  |                              "(select SUM(RealValue) from dbo.WbsDetail where Months<=t.Months and CHARINDEX(ToWbs,@ToWbs)>0) as 实耗累积值 " + | |||
|  |                              "from dbo.WbsDetail as t where CHARINDEX(t.ToWbs,@ToWbs)>0 order by t.Months"; | |||
|  |             string date = DateTime.Now.Year + "-" + DateTime.Now.Month + "-01"; | |||
|  |             SqlParameter[] parameter = new SqlParameter[] | |||
|  |                     { | |||
|  |                         new SqlParameter("@ToWbs",toWbs), | |||
|  |                         new SqlParameter("@Months",date), | |||
|  |                     }; | |||
|  |             DataTable dt = SQLHelper.GetDataTableRunText(strSql, parameter); | |||
|  |             this.Grid1.DataSource = dt; | |||
|  |             this.Grid1.DataBind(); | |||
|  |             this.ChartEV.CreateMaryChart(dt, 820, 320, null); | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region 将DataTable行列转换 | |||
|  |         /// <summary>   | |||
|  |         /// 将DataTable行列转换   | |||
|  |         /// </summary>   | |||
|  |         /// <param name="src">要转换的DataTable</param>   | |||
|  |         /// <param name="columnHead">要作为Column的哪列</param>   | |||
|  |         /// <returns></returns>   | |||
|  |         private DataTable Col2Row(DataTable src, int columnHead) | |||
|  |         { | |||
|  |             DataTable result = new DataTable(); | |||
|  |             DataColumn myHead = src.Columns[columnHead]; | |||
|  |             result.Columns.Add(myHead.ColumnName); | |||
|  |             FineUIPro.RenderField bf; | |||
|  |             bf = new FineUIPro.RenderField(); | |||
|  |             bf.ColumnID = myHead.ColumnName; | |||
|  |             bf.DataField = myHead.ColumnName; | |||
|  |             bf.HeaderText = myHead.ColumnName; | |||
|  |             Grid1.Columns.Add(bf); | |||
|  |             for (int i = 0; i < src.Rows.Count; i++) | |||
|  |             { | |||
|  |                 result.Columns.Add(src.Rows[i][myHead].ToString()); | |||
|  |                 bf = new FineUIPro.RenderField(); | |||
|  |                 bf.ColumnID = src.Rows[i][myHead].ToString(); | |||
|  |                 bf.DataField = src.Rows[i][myHead].ToString(); | |||
|  |                 bf.HeaderText = src.Rows[i][myHead].ToString(); | |||
|  |                 Grid1.Columns.Add(bf); | |||
|  |             } | |||
|  |             Grid1.DataKeyNames = new string[] { "月份" }; | |||
|  |             foreach (DataColumn col in src.Columns) | |||
|  |             { | |||
|  |                 if (col == myHead) | |||
|  |                     continue; | |||
|  |                 object[] newRow = new object[src.Rows.Count + 1]; | |||
|  |                 newRow[0] = col.ColumnName; | |||
|  |                 for (int i = 0; i < src.Rows.Count; i++) | |||
|  |                 { | |||
|  |                     newRow[i + 1] = src.Rows[i][col]; | |||
|  |                 } | |||
|  |                 result.Rows.Add(newRow); | |||
|  |             } | |||
|  |             return result; | |||
|  |         } | |||
|  | 
 | |||
|  |         private DataTable Col2Row(DataTable src, string columnHead) | |||
|  |         { | |||
|  |             for (int i = 0; i < src.Columns.Count; i++) | |||
|  |             { | |||
|  |                 if (src.Columns[i].ColumnName.ToUpper() == columnHead.ToUpper()) | |||
|  |                     return Col2Row(src, i); | |||
|  |             } | |||
|  |             return new DataTable(); | |||
|  |         } | |||
|  |         #endregion | |||
|  |     } | |||
|  | } |