2016-06-07 1 views
0

Je fais un service web où j'appelle des objets de données créés directement via linq, je me demandais comment convertir DateTime? directement à la chaîne ?, ceci, parce que je ne peux pas convertir le DateTime? à DateTime, puis à une chaîne à travers une variable ou un non, parce que linq ne me laisse pas.Comment convertir un DateTime? Chaîne directement (en C# linq)

Voici le code:

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(); 

toute question, suggestion ou commentaire d'améliorer la question serait appréciée ainsi que la réponse.

+2

BTW, vous pouvez écrire 'p.ID_ProgFecha ?? 0' – SLaks

+0

Il suffit de récupérer le 'DateTime's, faire la conversion dans les propriétés calculées dans' ItemAcciones'. –

Répondre

-1

C'est une solution manuelle, mais vous pouvez utiliser SqlFunctions pour gérer la chaîne de votre Date.

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(); 

Espérons que cela aide. =)

+0

Mauvais conseil. Cela déclenchera un chargement paresseux pour chaque objet imbriqué individuel ('p.Empresas' etc.) –