来点需要:我使用的数据库访问EF框架,但是,因为使用一个动态表来的统计报告中。单独是每天产生基于数据表,它是很难使用EF加盟前。所以我包装在两组数据库存取层的框内,一个是EF,一种是传统的ADO.NET。当设计使用动态表,我打电话跟ADO.NET进行数据库訪问操作了。

先看下View。这里我使用的是jquery easyUI里面的datagrid来做的报表。

例如以下:
单击选中日报:

年报例如以下:

@model YKT.Model.SubCompanyReport
@{ViewBag.Title = "分公司营收统计";Layout = "~/Views/Shared/Base.cshtml";
}
<style type="text/css">
.datagrid-header-row .datagrid-cell-group
{font-size:12px;font-weight:bold;
}
.datagrid-header td
{font-weight:bold;
}
</style>
<script src="../../Res/My97DatePicker/WdatePicker.js" type="text/javascript"></script>
<script type="text/javascript">var cTime = "";var cUser = '<div style="text-align: left; float:left;">制表人:</div>';var dataDate = "";var yearMonthTitle = "";var dayMonthTitle = "";var tbTitle="";//获取组织类型function getComponentType() {$("#sltCompany").empty();var url = "SubCompanyReport/GetComList"$.getJSON(url, function (data) {if (data != null) {$.each(data, function (i, item) {$("<option></option>").val(item["COMPONENT_ID"]).text(item["COMPONENT_NAME"]).appendTo($("#sltCompany"));});}});}//“查询”button。弹出查询框function flexiQuery() {if ($("#Start_Time").val() == "") {$.messager.alert('提示', '结算日期不能为空');}else {//将查询条件依照分隔符拼接成字符串var search = "Start_Time=" + $("#Start_Time").val() + "&&End_Time=" + $("#End_Time").val() + "&&sltCompany="
+ $("#sltCompany").val() + "&&sltReportType=" + $("#sltReportType").val();var url = 'SubCompanyReport/GetData?' + search;cTime = '<div style="text-align: left; float:left;">制表时间:' + CurentDate() + '</div>';var myDate = new Date();var startDate = StringToDate($("#Start_Time").val());dataDate = '<div style="text-align: left; float:left;">数据日期:';if ($("#sltReportType").val() == "0") {var endDate = StringToDate($("#End_Time").val());if (endDate == "") {dataDate += getDateByStr(startDate) + getWeek(startDate);}else {dataDate += getDateByStr(startDate) + getWeek(startDate) + " 到 " + getDateByStr(endDate) + getWeek(endDate);}dataDate += '</div>';$('#div1').panel('close');$('#div').panel('open');yearMonthTitle = "月累计";dayMonthTitle = "当日";//运行查询      getData(url);}else if ($("#sltReportType").val() == "1") {$('#div1').panel('close');$('#div').panel('open');var v = getDateByStr(startDate);dataDate += v.substring(0, 8);dayMonthTitle = "当月";yearMonthTitle = "年累计";dataDate += '</div>';//运行查询      getData(url);}else if ($("#sltReportType").val() == "2") {var v1 = getDateByStr(startDate);dataDate = v1.substring(0, 5);tbTitle = '公交总公司' + dataDate + '运营收入统计表(按分公司)';$('#div1').panel('open');$('#div').panel('close');dataDate += '</div>';//运行查询      getData1(url);}}}$(function () {initData();$("#sltReportType").change(function () {if ($("#sltReportType").val() == "0") {$("#spnEndTime").css("display", "inline");} else {$("#spnEndTime").css("display", "none");}});});//初始化数据function initData() {var d = getDate(0);$("#Start_Time").val(d);//$("#End_Time").val(d);getComponentType();}//导出function outputExcel() {$.messager.confirm('操作提示', "确认导出数据吗?

", function (r) { if (r) { //将查询条件依照分隔符拼接成字符串 var search = "Start_Time=" + $("#Start_Time").val() + "&&End_Time=" + $("#End_Time").val() + "&&sltCompany=" + $("#sltCompany").val() + "&&sltReportType=" + $("#sltReportType").val(); var url = 'SubCompanyReport/Export?' + search; window.location.href = url; } }); } //日报表 function getData(url) { var searchH = $("#divQuery").height(); var h = document.documentElement.clientHeight - searchH - 26; //var w = document.documentElement.clientWidth; $('#flexigridData').datagrid({ title: '分公司营收统计', //列表的标题 iconCls: 'icon-site', // fit: true, //列表自己主动适应宽度 width: 'auto', singleSelect: true, height: h, nowrap: false, //True 就会把数据显示在一行里。 striped: true, //True 就把行条纹化。(即奇偶行使用不同背景色) collapsible: true, //可调节列宽 //remoteSort: true, //定义是否从server给数据排序。 url: url, //获取数据的url toolbar: [], columns: [ [{ title: '公交公司全日运营收入统计表(按分公司)', colspan: 17,align:'center'}], //第一行 [{ title: '<div style="text-align: left; float:left;">制表单位:吴江公交总公司IC卡结算管理中心</div>', colspan: 8, headalign: 'left' },  { title: cTime, colspan: 7 }, { title: cUser, colspan: 2}], //第二行 [{ title: dataDate, colspan: 17}], //第三行 [{ title: '单位', rowspan: 3, field: 'ComponentName' }, { title: '投币收入', colspan: 4 }, { title: 'IC卡收入', colspan: 4 },  { title: 'IC卡收入占%', colspan: 4 }, { title: '合计', colspan: 4}], //第四行 [{ title: dayMonthTitle, colspan: 2 }, { title: yearMonthTitle, colspan: 2 }, { title: dayMonthTitle, colspan: 2 }, { title: yearMonthTitle, colspan: 2 }, { title: dayMonthTitle, colspan: 2 }, { title: yearMonthTitle, colspan: 2 }, { title: dayMonthTitle, colspan: 2 }, { title: yearMonthTitle, colspan: 2}], //第五行 [{ title: '人次(次)', field: 'tbrec' }, { title: '金额(元)', field: 'tbamt', width: 80 }, { title: '人次(次)', field: 'tbljrec' },  { title: '金额(元)', field: 'tbljamt', width: 80 }, { title: '人次(次)', field: 'icrec' }, { title: '金额(元)', field: 'icamt', width: 80 }, { title: '人次(次)', field: 'icljrec' }, { title: '金额(元)', field: 'icljamt', width: 80 }, { title: '人次(次)', field: 'dayrecPer' }, { title: '金额(元)', field: 'dayAmtPer' }, { title: '人次(次)', field: 'monthrecPer' },  { title: '金额(元)', field: 'monthAmtPer' }, { title: '人次(次)', field: 'dayrecTotal' }, { title: '金额(元)', field: 'dayAmtTotal',width:80 }, { title: '人次(次)', field: 'monthrecTotal' }, { title: '金额(元)', field: 'monthAmtTotal',width:80}], //第六行 ] //, //pagination: true, //在 datagrid 的底部显示分页栏。

//rownumbers: true //显示行号的列 }); //异步获取button //首先获取iframe标签的id值 var iframeid = window.parent.$('#tabs').tabs('getSelected').find('iframe').attr("id"); //然后关闭AJAX对应的缓存 $.ajaxSetup({ cache: false }); //获取button值 $.getJSON("../Home/GetToolbar", { id: iframeid }, function (data) { if (data == null) { return; } $('#flexigridData').datagrid("addToolbarItem", data); }); } //年报表 function getData1(url) { var searchH = $("#divQuery").height(); var h = document.documentElement.clientHeight - searchH - 26; //var w = document.documentElement.clientWidth; $('#flexigridData1').datagrid({ title: '分公司营收统计', //列表的标题 iconCls: 'icon-site', // fit: true, //列表自己主动适应宽度 width: 'auto', singleSelect: true, height: h, nowrap: false, //True 就会把数据显示在一行里。

striped: true, //True 就把行条纹化。

(即奇偶行使用不同背景色) collapsible: true, //可调节列宽 //remoteSort: true, //定义是否从server给数据排序。

url: url, //获取数据的url toolbar: [], columns: [ [{ title: tbTitle, colspan: 9, align: 'center'}], //第一行 [{ title: '<span style="text">制表单位:吴江公交总公司IC卡结算管理中心</span>', colspan: 4, headalign: 'left' }, { title: cTime, colspan: 3 }, { title: cUser, colspan: 2}], //第二行 [{ title: '单位', rowspan: 2, field: 'ComponentName' }, { title: '投币收入', colspan: 2 }, { title: 'IC卡收入', colspan: 2 },  { title: 'IC卡收入占%', colspan: 2 }, { title: '合计', colspan: 2}], //第三行 [{ title: '人次(次)', field: 'tbrec' }, { title: '金额(元)', field: 'tbamt', width: 120 }, { title: '人次(次)', field: 'icrec' },  { title: '金额(元)', field: 'icamt', width: 120 }, { title: '人次(次)', field: 'yearrecPer' }, { title: '金额(元)', field: 'yearAmtPer', width: 120 }, { title: '人次(次)', field: 'yearrecTotal' },  { title: '金额(元)', field: 'yearAmtTotal', width: 120}] ] //, //pagination: true, //在 datagrid 的底部显示分页栏。

//rownumbers: true //显示行号的列 }); //异步获取按钮 //首先获取iframe标签的id值 var iframeid = window.parent.$('#tabs').tabs('getSelected').find('iframe').attr("id"); //然后关闭AJAX对应的缓存 $.ajaxSetup({ cache: false }); //获取按钮值 $.getJSON("../Home/GetToolbar", { id: iframeid }, function (data) { if (data == null) { return; } $('#flexigridData1').datagrid("addToolbarItem", data); }); } </script> <div id="content" region="center" fit="true"> <form id="form1"> <div id="divQuery" style="padding: 5px; font-size: 12px;" title="查询列表" class="easyui-toolbar"> <span>结算日期:</span><span> <input type="text" readonly="readonly" id="Start_Time" οnclick="WdatePicker({maxDate:'#F{$dp.$D(\'End_Time\');}'})" /> </span> <span id="spnEndTime"> 到 <input type="text" readonly="readonly" id="End_Time" οnclick="WdatePicker({minDate:'#F{$dp.$D(\'Start_Time\');}'})" /></span> <span>公司类型:</span> <span><select id="sltCompany"></select></span> <span style=" margin:4px;">报表类型:</span><span><select id="sltReportType"> <option value="0">日报</option> <option value="1">月报</option> <option value="2">年报</option> </select></span> <a href="javascript:flexiQuery()" class="easyui-linkbutton" data-options="iconCls:'icon-search'">查询</a> <a href="javascript:resetData()" class="easyui-linkbutton" data-options="iconCls:'icon-redo'"> 重置</a> </div> </form> <div id="div" class="easyui-panel" closed="true"> <table id="flexigridData" style=" text-align:center"> </table> </div> <div id="div1" class="easyui-panel" closed="true"> <table id="flexigridData1" style=" text-align:center"> </table> </div> </div>

控制器SubCompanyReportController例如以下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using YKT.BLL;
using YKT.Common;
using YKT.Model;
using System.IO;
using Microsoft.Office.Interop.Excel;
using System.Text;namespace YKT.Controllers
{public class CompanyClass{public string COMPONENT_ID { get; set; }public string COMPONENT_NAME { get; set; }}public class SubCompanyReportController : Controller{#region 初始化string ClassName = "SubCompanyReport"; //类名SubCompanyReportService _service;public SubCompanyReportController(){if (_service == null){_service = new SubCompanyReportService();}}ValidationErrors validationErrors = new ValidationErrors();OMOPERATIONLOGTB OperLog = new OMOPERATIONLOGTB();#endregionpublic ActionResult Index(){return View();}public JsonResult GetComList(){System.Data.DataTable data = _service.GetComList(1, -1, 0, "COMMON,BUS");List<CompanyClass> list = new List<CompanyClass>();if (data != null && data.Rows.Count > 0){for (int i = 0; i < data.Rows.Count; i++){list.Add(new CompanyClass { COMPONENT_ID = data.Rows[i][0].ToString(), COMPONENT_NAME = data.Rows[i][1].ToString() });}}return Json(list, JsonRequestBehavior.AllowGet);}[HttpPost]public JsonResult GetData(string sltReportType, string Start_Time, string End_Time, string sltCompany, string sltSubCompany){List<SubCompanyReport> list = _service.GetTotalStatBySubCompany(sltReportType, Start_Time, End_Time);return Json(list, JsonRequestBehavior.AllowGet);}#region 导出/// <summary>/// 数据导出/// </summary>/// <param name="search"></param>/// <returns></returns>public ActionResult Export(string sltReportType, string Start_Time, string End_Time, string sltCompany, string sltSubCompany){List<SubCompanyReport> queryData = _service.GetTotalStatBySubCompany(sltReportType, Start_Time, End_Time);if (queryData == null || queryData.Count < 1){Response.Write("<script> alert('没有要导出的数据!

'); </script>"); return View("Index"); } int sheet; //结算起始时间 #region 导出Excel string newpath = AppDomain.CurrentDomain.BaseDirectory + "Excel\\"; string newFileName = newpath + "temp.xls";//+ Guid.NewGuid() if (!Directory.Exists(newpath)) { Directory.CreateDirectory(newpath); } //string newpath = Server.MapPath(".") + @"\Excel\" + Guid.NewGuid() + ".xls"; //调用的模板文件 FileInfo mode = new FileInfo(Server.MapPath("~/xlsMode/营收报表.xls")); Application app = new Application(); if (app == null) { return Json("当前用户电脑未安装EXCEL!", JsonRequestBehavior.AllowGet); } app.Application.DisplayAlerts = false; app.Visible = false; if (mode.Exists) { Workbook tworkbook; Object missing = System.Reflection.Missing.Value; app.Workbooks.Add(missing); string beginTime = string.IsNullOrEmpty(Start_Time) ? string.Empty : DateTime.Parse(Start_Time).ToString("yyyyMMdd"); string endTime = string.IsNullOrEmpty(End_Time) ?

string.Empty : DateTime.Parse(End_Time).ToString("yyyyMMdd"); //调用模板 写表头 tworkbook = app.Workbooks.Open(mode.FullName, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing); Worksheet tworksheet=new Worksheet(); string ctitle = "制表时间:"; string dataDateText = "数据日期:"; switch (sltReportType) { case "0": //日报 sheet = 8; tworksheet = (Worksheet)tworkbook.Sheets[sheet]; if (!string.IsNullOrEmpty(beginTime) && string.IsNullOrEmpty(endTime)) { dataDateText += ValueConvert.GetDatetimeString(beginTime); } else if (string.IsNullOrEmpty(beginTime) && !string.IsNullOrEmpty(endTime)) { dataDateText += ValueConvert.GetDatetimeString(endTime); } else if (!string.IsNullOrEmpty(beginTime) && !string.IsNullOrEmpty(endTime)) { dataDateText += ValueConvert.GetDatetimeString(beginTime) + " 到 " + ValueConvert.GetDatetimeString(endTime); ; } tworksheet.Cells[3, 9] = ctitle+ValueConvert.GetDatetimeString(DateTime.Now.ToString("yyyyMMdd")); tworksheet.Cells[4, 1] = dataDateText; break; case "1": //月报 sheet = 9; tworksheet = (Worksheet)tworkbook.Sheets[sheet]; tworksheet.Cells[1, 1] = "吴江市公交公司" + beginTime.Substring(4, 2) + "月份运营收入统计表(按分公司)"; tworksheet.Cells[3, 9] = ctitle + ValueConvert.GetDatetimeString(DateTime.Now.ToString("yyyyMMdd")); break; case "2": //年报 sheet = 10; tworksheet = (Worksheet)tworkbook.Sheets[sheet]; tworksheet.Cells[1, 1] = "吴江市公交公司" + beginTime.Substring(0, 4) + "年运营收入统计表(按分公司)"; tworksheet.Cells[3, 5] = ctitle + ValueConvert.GetDatetimeString(DateTime.Now.ToString("yyyyMMdd")); break; } #region 写Excel的内容 if (queryData != null && queryData.Count > 0) { if (sltReportType == "0" || sltReportType == "1") { int m = 7; for (int i = 0; i < queryData.Count; i++) { tworksheet.Cells[m + i, 1] = queryData[i].ComponentName; tworksheet.Cells[m + i, 2] = queryData[i].tbrec; tworksheet.Cells[m + i, 3] = queryData[i].tbamt; tworksheet.Cells[m + i, 4] = queryData[i].tbljrec; tworksheet.Cells[m + i, 5] = queryData[i].tbljamt; tworksheet.Cells[m + i, 6] = queryData[i].icrec; tworksheet.Cells[m + i, 7] = queryData[i].icamt; tworksheet.Cells[m + i, 8] = queryData[i].icljrec; tworksheet.Cells[m + i, 9] = queryData[i].icljamt; tworksheet.Cells[m + i, 10] = queryData[i].dayrecPer; tworksheet.Cells[m + i, 11] = queryData[i].dayAmtPer; tworksheet.Cells[m + i, 12] = queryData[i].monthrecPer; tworksheet.Cells[m + i, 13] = queryData[i].monthAmtPer; tworksheet.Cells[m + i, 14] = queryData[i].dayrecTotal; tworksheet.Cells[m + i, 15] = queryData[i].dayAmtTotal; tworksheet.Cells[m + i, 16] = queryData[i].monthrecTotal; tworksheet.Cells[m + i, 17] = queryData[i].monthAmtTotal; } } else if (sltReportType == "2") { int m = 4; for (int i = 0; i < queryData.Count; i++) { tworksheet.Cells[m + i, 1] = queryData[i].ComponentName; tworksheet.Cells[m + i, 2] = queryData[i].tbrec; tworksheet.Cells[m + i, 3] = queryData[i].tbamt; tworksheet.Cells[m + i, 4] = queryData[i].icrec; tworksheet.Cells[m + i, 5] = queryData[i].icamt; tworksheet.Cells[m + i, 6] = queryData[i].yearrecPer; tworksheet.Cells[m + i, 7] = queryData[i].yearAmtPer; tworksheet.Cells[m + i, 8] = queryData[i].yearrecTotal; tworksheet.Cells[m + i, 9] = queryData[i].yearAmtTotal; } } } #endregion tworksheet.SaveAs(newFileName, missing, missing, missing, missing, missing, missing, missing, missing, missing); tworkbook.Close(false, mode.FullName, missing); app.Workbooks.Close(); app.Quit(); tworkbook = null; app = null; //强制对全部代进行垃圾回收 GC.Collect(); } System.IO.FileInfo file = new System.IO.FileInfo(newFileName); Response.Clear(); Response.Charset = "GB2312"; Response.ContentEncoding = System.Text.Encoding.Default; // 加入头信息,为"文件下载/另存为"对话框指定默认文件名称 string nm = "分公司_" + mode.Name; Response.AddHeader("Content-Disposition", "attachment; filename=" +HttpUtility.UrlEncode(nm, Encoding.UTF8).ToString() ); //Server.UrlEncode(mode.Name)); // 加入头信息,指定文件大小。让浏览器可以显示下载进度 Response.AddHeader("Content-Length", file.Length.ToString()); // 指定返回的是一个不能被client读取的流。必须被下载 Response.ContentType = "application/ms-excel"; // 把文件流发送到client Response.WriteFile(file.FullName); // 停止页面的运行 Response.End(); return Json("导出成功!", JsonRequestBehavior.AllowGet); #endregion } #endregion } }

版权声明:本文博客原创文章。博客,未经同意,不得转载。

5、VS2010+ASP.NET MVC4+EF4+JqueryEasyUI+Oracle该项目的开发——使用datagrid做报表相关推荐

  1. VS2010 ASP.NET MVC4 安装失败问题

    运行个MVC项目,编译不通过找解决方案,原来MVC项目还必须单独安装一个MVC. 由于我安装的是VS2010所以找了个在线安装MVC4VS2010.exe ,安装这个时间长呀,我都睡了好几觉才安完,而 ...

  2. ASP.NET MVC4中用 BundleCollection

    来源:http://www.cnblogs.com/madyina/p/3702314.html ASP.NET MVC4中对JS和CSS的引用又做了一次变化,在MVC3中我们这样引用资源文件: &l ...

  3. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(12)-系统日志和异常的处理②...

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(12)-系统日志和异常的处理② 上一讲我们做了日志与异常的结果显示列表,这一节我们讲要把他应用系统中来. ...

  4. ASP.NET MVC4中调用WEB API的四个方法

    当今的软件开发中,设计软件的服务并将其通过网络对外发布,让各种客户端去使用服务已经是十分普遍的做法.就.NET而言,目前提供了Remoting,WebService和WCF服务,这都能开发出功能十分强 ...

  5. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(31)-MVC使用RDL报表

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(31)-MVC使用RDL报表 这次我们来演示MVC3怎么显示RDL报表,坑爹的微软把MVC升级到5都木有良 ...

  6. .ne中的控制器循环出来的数据如何显示在视图上_Web程序设计-ASP.NET MVC4数据库操作实例...

    ASP.NET MVC4数据库操作实例 之前文章介绍了MVC4与Pure框架结合进行的网页设计过程中如何定义控制器.方法.模型.视图等.并使用实例进行了简单说明.本文将在此基础上进一步说明如何使用MV ...

  7. 【翻译转载】【官方教程】Asp.Net MVC4入门指南(2):添加一个控制器

    2. 添加一个控制器 · 原文地址:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/adding-a-c ...

  8. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(32)-swfupload多文件上传[附源码]...

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(32)-swfupload多文件上传[附源码] 文件上传这东西说到底有时候很痛,原来的asp.net服务器 ...

  9. Asp.Net MVC4入门指南(3):添加一个视图

    在本节中,您需要修改HelloWorldController类,从而使用视图模板文件,干净优雅的封装生成返回到客户端浏览器HTML的过程. 您将创建一个视图模板文件,其中使用了ASP.NET MVC ...

  10. ASP.NET MVC4中@model使用多个类型实例的方法

    有时需要在ASP.NET MVC4的视图的@model中使用多个类型的实例,.NET Framework 4.0版本引入的System.Tuple类可以轻松满足这个需求. 假设Person和Produ ...

最新文章

  1. oracle 24365,深入解析:DBA_OBJECTS中的OBJECT_ID与DATA_OBJECT_ID的区别
  2. Delphi 多文件拖放获取路径示例
  3. 枚举类的使用-使用实例域来替代序数
  4. 77.SQL 查询方式整理
  5. 处理时间_1_对时间列进行加减
  6. java rhino_在Java 8中使用Rhino
  7. linux不支持32,Visual Studio Code 1.36发布,不再支持Linux 32位
  8. hover 插入html元素,解决hover生成border造成的元素移动方法
  9. 人教版四年级上次计算机教案,人教版四年级上册数学教案
  10. 微信小程序 audio 音频 组件
  11. 函数发生器的使用方法
  12. 14年第五届蓝桥杯C/C++大学B组真题———史丰收算法
  13. lenovo启动热键_常见电脑启动项热键
  14. 2019年6月中国编程语言排行榜
  15. nordic NRFX驱动和NRF驱动
  16. css 网格布局_CSS网格布局三年
  17. mac安装mysql方法
  18. GPT专业应用:快速生成职位描述(JD)
  19. msvcp140.dll重新安装的解决方法【msvcp140.dll修复工具下载】
  20. IOS xib三等分,四等分控件

热门文章

  1. mysql 创建xml字段_使用PHP DOM从MySQL数据创建XML文件
  2. python 摄像头采集_Python+OpenCV采集本地摄像头的视频
  3. Struts2中过滤器和拦截器的区别
  4. SVM入门(五)线性分类器的求解——问题的描述Part2
  5. POJ1001 —— Exponentiation(高精度幂问题)
  6. Chrome开发者工具对于异常请求不显示Response内容
  7. Oracle----oracle小知识总结
  8. Linux0.11内核--进程调度分析之1.初始化
  9. SQLSERVER数据库所有者SID问题
  10. 如何实现:GridView 控件中显示的文本不自动换行,隐藏超出宽度部分wj-wangjun