峰峦@叠嶂 2024-07-17 09:34 采纳率: 99.5%
浏览 3
已结题

按条件区分显示合计行的问题

请教一下,我为业务部门制作的这个月度考核统计表,查询后按班组分类并统计合计,现在需要按不同的产品类型再区分显示,但这样的话,那些不符条件,不能显示的查询内容的合计还在,请问如何能灵活的,按条件来显示内容与合计行呢,截图与代码如下,敬请指导,谢谢;

img


   string startdate = comdate.Text;
   //---------------------------------------0716,以下,是为了区分制剂一和二所加;
   string comtype = comType.Text;                                             

   string teamsFilter = "";

   if (comtype == "制剂一")
   {
       teamsFilter = "teams <> '液体制剂组' AND teams <> '液体包装组'";
   }
   else if (comtype == "制剂二")
   {
       teamsFilter = "teams <> '片剂外包组' AND teams <> '颗粒制剂组' AND teams <> '片剂制剂组'";
   }

   //Sqlstring = @"select * from w_TCSalary where dateInfo = @startdate order by departMent ,teams";
   Sqlstring = @"select * from w_TCSalary where dateInfo = @startdate";

   if (!string.IsNullOrEmpty(teamsFilter))
   {
       Sqlstring += " AND " + teamsFilter;
   }

   Sqlstring += " order by departMent , teams"; // 0716 , +=号,是为了追加后面的查询条件;
//-----------------------------------------------------
   SqlCommand Cmd = new SqlCommand(Sqlstring, Conn);

   Cmd.Parameters.AddWithValue("@startdate", startdate);

   SqlDataAdapter sda = new SqlDataAdapter(Cmd);

   dt.Rows.Clear();
   dt.Columns.Clear();
   dataGridView1.Columns.Clear();

   sda.Fill(dt);

   //-------------------------------------------------------------------------- 0710 按班组分类;

   DataTable dtTeams = new DataTable();
   string  sqlstring = $"select distinct teams from w_TCSalary where dateInfo='{startdate}' order by teams asc";
   Cmd = new SqlCommand(sqlstring, Conn);
   sda = new SqlDataAdapter(Cmd);
   sda.Fill(dtTeams);

   dtSum = dt.Clone();
   dtSum.Clear();

   // 计算各班组合计值并插入到原始数据表中
   foreach (DataRow teamRow in dtTeams.Rows)
   {
      //---------------------0716,按制剂类型分类

       string teamName = teamRow["teams"].ToString();

       // 筛选出当前班组的数据行
       DataRow[] rows = dt.Select($"teams = '{teamName}'");
                              
       //------------------------------------------
       
       // 计算该班组的合计值
       decimal sum1 = 0, sum2 = 0, sum3 = 0, sum4 = 0, sum5 = 0;                           

       foreach (DataRow row in rows)
       {
           sum1 += Convert.ToDecimal(row["workday"]);
           sum2 += Convert.ToDecimal(row["Smanage"]);
           sum3 += Convert.ToDecimal(row["reward"]);
           sum4 += Convert.ToDecimal(row["pamount"]);
           sum5 += Convert.ToDecimal(row["Salary"]);

           // 将数据行添加到结果表中
           dtSum.ImportRow(row);
       }

       // 创建合计行并插入到数据表中
       DataRow totalRow = dtSum.NewRow();
       totalRow["teams"] = "合计";
       totalRow["workday"] = sum1;
       totalRow["Smanage"] = sum2;
       totalRow["reward"] = sum3;
       totalRow["pamount"] = sum4;
       totalRow["Salary"] = sum5;

       dtSum.Rows.Add(totalRow);
   }
  • 写回答

6条回答 默认 最新

  • 峰峦@叠嶂 2024-07-17 11:08
    关注

    采用datagridview里面,设定条件,若不符条件的,直接将该行设置为不显示visible,即可;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 7月25日
  • 已采纳回答 7月17日
  • 创建了问题 7月17日

悬赏问题

  • ¥15 12864只亮屏 不显示汉字
  • ¥20 三极管1000倍放大电路
  • ¥15 vscode报错如何解决
  • ¥15 前端vue CryptoJS Aes CBC加密后端java解密
  • ¥15 python随机森林对两个excel表格读取,shap报错
  • ¥15 基于STM32心率血氧监测(OLED显示)相关代码运行成功后烧录成功OLED显示屏不显示的原因是什么
  • ¥100 X轴为分离变量(因子变量),如何控制X轴每个分类变量的长度。
  • ¥30 求给定范围的全体素数p的(p-2)/p的连乘积值
  • ¥15 VFP如何使用阿里TTS实现文字转语音?
  • ¥100 需要跳转番茄畅听app的adb命令