Estoy tratando de obtener mi declaración de linq para obtener todos los registros entre dos fechas, y no estoy muy seguro de lo que necesito cambiar para que funcione: (a.Start >= startDate && endDate)
var appointmentNoShow =
from a in appointments
from p in properties
from c in clients
where a.Id == p.OID && (a.Start.Date >= startDate.Date && endDate)
Respuestas:
Solo cámbialo a
var appointmentNoShow = from a in appointments from p in properties from c in clients where a.Id == p.OID && (a.Start.Date >= startDate.Date && a.Start.Date <= endDate)
fuente
.Date
llamada en unaEntityFunctions.TruncateDate
llamada.var appointmentNoShow = from a in appointments from p in properties from c in clients where a.Id == p.OID where a.Start.Date >= startDate.Date where a.Start.Date <= endDate.Date
fuente
var QueryNew = _context.Appointments.Include(x => x.Employee).Include(x => x.city).Where(x => x.CreatedOn >= FromDate).Where(x => x.CreatedOn <= ToDate).Where(x => x.IsActive == true).ToList();
fuente
public List<tbltask> gettaskssdata(int? c, int? userid, string a, string StartDate, string EndDate, int? ProjectID, int? statusid) { List<tbltask> tbtask = new List<tbltask>(); DateTime sdate = (StartDate != "") ? Convert.ToDateTime(StartDate).Date : new DateTime(); DateTime edate = (EndDate != "") ? Convert.ToDateTime(EndDate).Date : new DateTime(); tbtask = entity.tbltasks.Include(x => x.tblproject).Include(x => x.tbUser). Where(x => x.tblproject.company_id == c && (ProjectID == 0 || ProjectID == x.tblproject.ProjectId) && (statusid == 0 || statusid == x.tblstatu.StatusId) && (a == "" || (x.TaskName.Contains(a) || x.tbUser.User_name.Contains(a))) && ((StartDate == "" && EndDate == "") || ((x.StartDate >= sdate && x.EndDate <= edate)))).ToList(); return tbtask; }
esta es mi consulta para registros de búsqueda basados en datos de búsqueda y entre la fecha de inicio y finalización
fuente
Si alguien está interesado en saber cómo trabajar con 2 listas y entre fechas
var newList = firstList.Where(s => secondList.Any(secL => s.Start > secL.RangeFrom && s.End < secL.RangeTo))
fuente
Si tiene una condición de filtro de intervalo de fechas y necesita seleccionar todos los registros que caen parcialmente en este rango de filtro. Supuesto: los registros tienen la propiedad ValidFrom y ValidTo.
DateTime intervalDateFrom = new DateTime(1990, 01, 01); DateTime intervalDateTo = new DateTime(2000, 01, 01); var itemsFiltered = allItems.Where(x=> (x.ValidFrom >= intervalDateFrom && x.ValidFrom <= intervalDateTo) || (x.ValidTo >= intervalDateFrom && x.ValidTo <= intervalDateTo) || (intervalDateFrom >= x.ValidFrom && intervalDateFrom <= x.ValidTo) || (intervalDateTo >= x.ValidFrom && intervalDateTo <= x.ValidTo) );
fuente
Entonces, se está desplazando hacia abajo porque las Respuestas no funcionan:
Esto funciona como magia (pero dicen que tiene problemas de eficiencia para big data, y a ti no te importa como a mí)
1- El tipo de datos en la base de datos es "datetime" y "anulable" en mi caso.
El formato de datos de ejemplo en DB es como:
2018-11-06 15:33:43.640
Un en C # cuando se convierte en cadena es como:
2019-01-03 4:45:16 PM
Entonces el formato es:
2- Por lo tanto, primero debe preparar sus variables de fecha y hora en el formato adecuado:
Ejemplo 1
yourDate.ToString("yyyy/MM/dd hh:mm:ss tt")
Ejemplo 2: intervalo de fecha y hora de los últimos 30 días
DateTime dateStart = DateTime.Now.AddDays(-30); DateTime dateEnd = DateTime.Now.AddDays(1).AddTicks(-1);
3- Finalmente la consulta linq que perdiste tu día tratando de encontrar (Requiere EF 6)
using System.Data.Entity; _dbContext.Shipments.Where(s => (DbFunctions.TruncateTime(s.Created_at.Value) >= dateStart && DbFunctions.TruncateTime(s.Created_at.Value) <= dateEnd)).Count();
Para tener en cuenta la comparación de tiempos también:
Tenga en cuenta que el siguiente método mencionado en otras preguntas y respuestas de stackoverflow no funcionará correctamente:
Si el día de inicio fue en este mes, por ejemplo, y el día de finalización es en el mes siguiente, la consulta devolverá falso y ningún resultado, por ejemplo:
DatabaseCreatedAtItemThatWeWant = 2018/12/05
startDate = 2018/12/01
EndDate = 2019/01/04
la consulta siempre buscará días entre 01 y 04 sin tener en cuenta el "mes", por lo que "s.Created_at.Value.Day <= dateEnd.Day" fallará
Y en caso de que tenga realmente grandes datos, ejecutaría Native SQL Query en lugar de linq
... ... where Shipments.Created_at BETWEEN CAST(@Created_at_from as datetime) AND CAST(@Created_at_to as datetime)) ....
Gracias
fuente
Tuve un problema para que esto funcionara.
Tenía dos fechas en una línea de base de datos y necesito agregarlas a una lista para ayer, hoy y mañana.
esta es mi solución:
var yesterday = DateTime.Today.AddDays(-1); var today = DateTime.Today; var tomorrow = DateTime.Today.AddDays(1); var vm = new Model() { Yesterday = _context.Table.Where(x => x.From <= yesterday && x.To >= yesterday).ToList(), Today = _context.Table.Where(x => x.From <= today & x.To >= today).ToList(), Tomorrow = _context.Table.Where(x => x.From <= tomorrow & x.To >= tomorrow).ToList() };
fuente