2016-06-07 1 views
0

Я делаю веб-службу, где я вызываю объекты данных, которые создаются непосредственно через linq, мне было интересно, как я могу преобразовать DateTime? прямо к string ?, это, потому что я не могу преобразовать DateTime? на DateTime, а затем на строку через переменную или что нет, потому что linq не позволяет мне.Как преобразовать DateTime? to String напрямую (в 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', сделайте преобразование в вычисленных свойствах в' 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' и т. Д.). –