Linq to sql中的 两日期相减问题

takako_mu 2010-12-25 04:45:10

private void MailAlert()
{
string[] s = "P1,3,24;P2,2,12;P3,1,4".Split(';');
List<Level> LLevel = new List<Level>();
int maxDay = -1, minDay = 0;
for (int i = 0; i < s.Length; i++)
{
Level l = new Level(s[i].Substring(0, s[i].IndexOf(',')), int.Parse(s[i].Substring(s[i].IndexOf(',') + 1, s[i].LastIndexOf(',') - s[i].IndexOf(',') - 1).Trim()), int.Parse(s[i].Substring(s[i].LastIndexOf(',') + 1, s[i].Length - s[i].LastIndexOf(',') - 1).Trim()));
LLevel.Add(l);
if (l.Day > maxDay) maxDay = l.Day;
if (l.Day < minDay) minDay = l.Day;
}
LLevel = LLevel.OrderByDescending(t => t.Howofen).ToList();//需排序,否則會重複發!
PCRDataContext db = new PCRDataContext();
var pcrDetail = from p in db.PcrDetail
where new string[] { "Open", "Reject" }.Contains(p.Task_Status) && !p.Project_No.ToLower().StartsWith("tmp")
&& DateTime.Now.Subtract(DateTime.Parse(p.Task_DueDate)).Days >= minDay
select p;
foreach (PcrDetail pp in pcrDetail)
{
List<Level> myLevel = LLevel.Where(p => p.Name.ToLower() == pp.Task_MailAlert.ToLower()).ToList();
int m = DateTime.Now.Subtract(DateTime.Parse(pp.Task_DueDate)).Days;
if (DateTime.Now.Subtract(DateTime.Parse(pp.Task_DueDate)).Days == myLevel[0].Day && DateTime.Now.Hour % myLevel[0].Howofen == 0)
{
SendMail();
}
}
}

初学Linq,请教一个问题。
在linq to sql查询语法中有一段条件:
&& DateTime.Now.Subtract(DateTime.Parse(p.Task_DueDate)).Days >= minDay

在Debug时候跑到foreach (PcrDetail pp in pcrDetail)时报错:
方法 'System.DateTime Parse(System.String)' 沒有支援的轉譯為 SQL。

如果将 && DateTime.Now.Subtract(DateTime.Parse(p.Task_DueDate)).Days >= minDay拿掉就不报错。

请问:原始sql:and datediff(dd,getdate(),task_duedate) between @minDay and @maxDay 在Linq中应该如何表示呢?
...全文
711 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
claymore1114 2010-12-25
  • 打赏
  • 举报
回复
既能 Subtract有问题,你可以直接相减。

//DateTime.Now.Subtract(DateTime.Parse(p.Task_DueDate)).Days >= minDay
(DateTime.Now-(DateTime.Parse(p.Task_DueDate)).Days >= minDay

q107770540 2010-12-25
  • 打赏
  • 举报
回复
DateTime.Now.Subtract(DateTime.Parse(p.Task_DueDate)).Days >= minDay

将此段判断封装成独立方法 放在查询语句外边 返回bool值

在查询语句中调用此方法也是可以的
takako_mu 2010-12-25
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 wuyq11 的回复:]
SqlMethods.DateDiffMonth(i.DateStart, i.DateEnd);
System.Data.Linq.SqlClient.SqlMethods.DateDiffDay(v.DateStart, DateTime.Now) < 0
[/Quote]
thank you!
wuyq11 2010-12-25
  • 打赏
  • 举报
回复
SqlMethods.DateDiffMonth(i.DateStart, i.DateEnd);
System.Data.Linq.SqlClient.SqlMethods.DateDiffDay(v.DateStart, DateTime.Now) < 0
yqyqyoyo 2010-12-25
  • 打赏
  • 举报
回复
帮忙顶。。。顺带拿下SF。这个问题我也不知道。。。

62,047

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧