转换为值类型'System.Int32'失败,因为实现值为null

时间:2015-05-09 20:11:33

标签: c# asp.net-mvc entity-framework crystal-reports

这是我的家庭控制器:

using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.IO;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using Biblioteca.Models;
using CrystalDecisions.CrystalReports.Engine;

namespace Biblioteca.Controllers
{
    public class HomeController : Controller
    {
        private BibliotecaDatabase db = new BibliotecaDatabase();

        public ActionResult Index()
        {
            var totalesviewmodel = new TotalesViewModel();
            totalesviewmodel.MontoCopias = db.AlumnosList.Sum(o => o.Copias);
            totalesviewmodel.MontoImpresiones = db.AlumnosList.Sum(o => o.Impresiones);
            totalesviewmodel.DineroDeposito = db.AlumnosList.Sum(o => o.Deposito);
            totalesviewmodel.DineroSap = db.AlumnosList.Sum(o => o.Sap);
    // *** here is my issue ***
            totalesviewmodel.MontoCopiasMaestro = db.MaestrosList.Sum(o => o.Copias);
            totalesviewmodel.MontoImpresionesMaestro = db.MaestrosList.Sum(o => o.Impresiones);
            return View(totalesviewmodel);
        }

        public ActionResult Reports()
        {
            List<Alumno> allDatos = new List<Alumno>();
            using (BibliotecaEntities dc = new BibliotecaEntities())
            {
                allDatos = dc.Alumnos.ToList();
            }
            return View(allDatos);
        }

        public ActionResult ExportReport()
        {
            List<Alumno> allDatos = new List<Alumno>();
            using (BibliotecaEntities dc = new BibliotecaEntities())
            {
                allDatos = dc.Alumnos.ToList();

                ReportDocument rd = new ReportDocument();
                rd.Load(Path.Combine(Server.MapPath("~/Reports"), "rpt_datos.rpt"));
                rd.SetDataSource(allDatos);

                Response.Buffer = false;
                Response.ClearContent();
                Response.ClearHeaders();

                try
                {
                    Stream stream = rd.ExportToStream(CrystalDecisions.Shared.ExportFormatType.PortableDocFormat);
                    stream.Seek(0, SeekOrigin.Begin);
                    return File(stream, "application/pdf", "Reporte.pdf");
                }
                catch (Exception ex)
                {
                    throw;
                }
            }
        }

        public ActionResult Contact ()
        {
            ViewBag.Message = "Your contact page.";
            return View();
        }
    }
}

在这一行:

totalesviewmodel.MontoCopiasMaestro = db.MaestrosList.Sum(o => o.Copias);

我收到此错误:

  

转换为值类型'System.Int32'失败,因为具体化值为null

在安装水晶报告之前,我没有这个问题。

我做错了什么?

1 个答案:

答案 0 :(得分:0)

我解决了这个问题,当你没有在数据库上注册时会发生错误,所以你需要插入一个工作:D

相关问题