J'essaie d'obtenir que ma déclaration linq me donne tous les enregistrements entre deux dates et je ne suis pas tout à fait sûr de ce que je dois changer pour que cela fonctionne: (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)
Il suffit de le changer pour
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)
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
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();
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;
}
cette ma requête pour les enregistrements de recherche basés sur searchdata et entre la date de début à la fin
J'ai eu un problème pour que cela fonctionne.
J'ai eu deux dates dans une ligne de base de données et je dois les ajouter à une liste pour hier, aujourd'hui et demain.
c'est ma solution:
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()
};
Donc, vous faites défiler parce que les réponses ne fonctionnent pas:
Cela fonctionne comme par magie (mais ils disent qu'il y a des problèmes d'efficacité pour les mégadonnées, et vous vous en fichez, tout comme moi)
1- Le type de données dans la base de données est "datetime" et "nullable" dans mon cas.
Exemple de format de données dans la base de données ressemble à ceci:
2018-11-06 15:33:43.640
Un C # converti en chaîne ressemble à ceci:
2019-01-03 4:45:16 PM
Le format est donc:
yyyy/MM/dd hh:mm:ss tt
2- Vous devez donc préparer vos variables datetime au format approprié en premier:
Exemple 1
yourDate.ToString("yyyy/MM/dd hh:mm:ss tt")
Exemple 2 - Plage de date/heure pour les 30 derniers jours
DateTime dateStart = DateTime.Now.AddDays(-30);
DateTime dateEnd = DateTime.Now.AddDays(1).AddTicks(-1);
3- Enfin, la requête linq que vous avez perdu votre journée à essayer de trouver (Nécessite 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();
Pour prendre également en compte la comparaison de temps:
(DbFunctions.CreateDateTime(s.Created_at.Value.Year, s.Created_at.Value.Month, s.Created_at.Value.Day, s.Created_at.Value.Hour, s.Created_at.Value.Minute, s.Created_at.Value.Second) >= dateStart && DbFunctions.CreateDateTime(s.Created_at.Value.Year, s.Created_at.Value.Month, s.Created_at.Value.Day, s.Created_at.Value.Hour, s.Created_at.Value.Minute, s.Created_at.Value.Second) <= dateEnd)
Notez la méthode suivante mentionnée sur d'autres questions et réponses stackoverflow ne fonctionnera pas correctement:
....
&&
(
s.Created_at.Value.Day >= dateStart.Day && s.Created_at.Value.Day <= dateEnd.Day &&
s.Created_at.Value.Month >= dateStart.Month && s.Created_at.Value.Month <= dateEnd.Month &&
s.Created_at.Value.Year >= dateStart.Year && s.Created_at.Value.Year <= dateEnd.Year
)).count();
si le jour de début était par exemple ce mois-ci et que le jour de fin était le mois suivant, la requête renverrait false et aucun résultat, par exemple:
DatabaseCreatedAtItemThatWeWant = 2018/12/05
startDate = 2018/12/01
EndDate = 2019/01/04
la requête recherchera toujours les jours compris entre 01 et 04 sans prendre en compte le "mois", de sorte que "s.Created_at.Value.Day <= dateEnd.Day" échouera
Et si vous avez vraiment de gros volumes de données, vous exécuterez Native SQL Query plutôt que linq.
...
... where Shipments.Created_at BETWEEN CAST(@Created_at_from as datetime) AND CAST(@Created_at_to as datetime))
....
Merci