2016-06-07 30 views
0

我正在做一个Web服务,我打电话通过LINQ直接创建的数据对象,我想知道,我可以如何转换DateTime?直接到字符串?,这,因为我不能转换DateTime?到DateTime然后通过一个变量或一个什么不是,因为linq不让我。如何转换DateTime?直接字符串(在C#linq)

下面的代码:

lista = (from p in db.Acciones 
    select new ItemAcciones 
    { 
     ID_Accion = p.ID_Accion, 

     FechaHora = p.FechaHora != null ? (DateTime)p.FechaHora : DateTime.Now, 
     //ShowFechaHora = !String.IsNullOrWhiteSpace(((DateTime)p.FechaHora).ToString("HH:mm")) ? ((DateTime)p.FechaHora).ToString("HH:mm") : DateTime.Now.ToString("HH:mm"), 

     ID_EmpresaNombre = p.Empresas.EmpresaNombre, 
     ID_ResponsableNombre = p.Responsables.LoginID, 
     ID_ContactoNombre = p.Contactos.Nombres + " " + p.Contactos.Paterno + " " + p.Contactos.Materno, 
     ID_AccionTipoNombre = p.AccionTipos.AccionTipoGlosa, 
     ID_AccionEstadoNombre = p.AccionEstados.AccEstGlosa, 
     AccionGlosa = p.AccionGlosa, 
     ID_Empresa = p.ID_Empresa, 
     AccionDescripcion = p.AccionDescripcion, 
     ID_Negocio = (int?)p.ID_Negocio ?? 0, 
     ID_Contacto = p.ID_Contacto, 
     ID_AccionTipo = p.ID_AccionTipo, 
     ID_AccionEstado = p.ID_AccionEstado, 

     ID_ProgFecha = p.ID_ProgFecha != null ? (int)p.ID_ProgFecha : 0, 
     ShowID_ProgFecha = String.IsNullOrWhiteSpace(p.ID_ProgFecha.ToString()) ?? p.ID_ProgFecha.ToString() : "--/--/----", 
     //ShowID_ProgFecha = StringAEstilizarComoDate(Convert.ToString(p.ID_ProgFecha)), 

     ID_ProgHora = p.ID_ProgHora != null ? (int)p.ID_ProgHora : 0, 
     //ShowID_ProgHora = StringAEstilizarComoHora(Convert.ToString(p.ID_ProgHora)), 

     ID_EjecFecha = p.ID_EjecFecha != null ? (int)p.ID_EjecFecha : 0, 
     //ShowID_EjecFecha = StringAEstilizarComoDate(Convert.ToString(p.ID_EjecFecha)), 

     ID_EjecHora = p.ID_EjecHora != null ? (int)p.ID_EjecHora : 0, 
     //ShowID_EjecHora = StringAEstilizarComoHora(Convert.ToString(p.ID_EjecHora)), 

     ID_Responsable = p.ID_Responsable, 
     EmpresaRUTCompleto = p.Empresas.EmpresaRut.ToString() + "-" + p.Empresas.EmpresaDV, 
     ID_NegocioNombre = p.Negocios.ProyectoNombre, 
    }).ToList(); 

任何疑问,建议或意见,以改善这个问题,将不胜感激,以及答案。

+2

顺便说一句,你可以写'p.ID_ProgFecha ?? 0' – SLaks

+0

只需获取'DateTime's,在'ItemAcciones'的计算属性中进行转换。 –

回答

-1

这是一个手动解决方案,但您可以使用SqlFunctions来处理日期的字符串。

var qqqq = db.YourTable.Select(q => (q.YourDate == null ? "" : (SqlFunctions.DateName("day",q.YourDate) + "/" + SqlFunctions.DateName("month", q.YourDate) + "/" + SqlFunctions.DateName("year", q.YourDate) + " " + SqlFunctions.DateName("hour", q.YourDate) + " " + SqlFunctions.DateName("minute", q.YourDate)))).ToList(); 

希望有帮助。 =)

+0

不好的建议。这将触发每个嵌套对象的延迟加载('p.Empresas'等) –