所以我试图从脚本任务中的表中获取最近的记录。该错误是在未来的LINQ查询,它看起来像:在linq的日期时间
"Could not Translate expression 'Table(SSASLogging).Select(r=>r.TimeStamp).Max()' into SQL and could not treat it as a local expression."
问题在于DateTime数据类型,但我需要的日期时间把它给我的SSIS变量。我知道这可以在一个执行SQL任务中轻松完成,但是我现在太放弃了!我知道有一些用于DateTime的LinqToSQL方法,但它们用于比较它看起来像,我不知道如何在这里应用它们。
public DateTime getLatest()
{
DateTime result = new DateTime();
//temp dummy/defaul date is two days ago
result = DateTime.Now.AddDays(-2);
try
{
//get the data connection string from the connection manager
RW = (string)Dts.Connections["ReportingWarehouse"].ConnectionString;
//Remove the Provider, Auto Translate, and Application
//as it is not a parameter for the DataContext constructor
RW = RW.Remove(RW.IndexOf("Provider=SQLNCLI10.1;"), "Provider=SQLNCLI10.1;".Length);
RW = RW.Remove(RW.IndexOf("Auto Translate=False;"), "Provider=SQLNCLI10.1;".Length);
RW = RW.Remove(RW.IndexOf("Application"),RW.Length - RW.IndexOf("Application"));
MessageBox.Show(RW);
//get the last insertion date from the SSASLoging table
using (DataContext RWData = new DataContext(RW))
{
Table<SSASLogging> records = RWData.GetTable<SSASLogging>();
var rs = (from r in records
select r.TimeStamp).Max();
//result = rs.FirstOrDefault();
}
}
catch (Exception e)
{
MessageBox.Show("Exception in Retrieving latesttime" + e.Message + "/n"
+ e.StackTrace);
}
return result;
}
}//end partial class
[Table]
public class SSASLogging
{
[Column(Name = "CREATED_TIMESTAMP")]
private DateTime timeStamp;
public DateTime TimeStamp
{
get { return this.TimeStamp; }
}
}//End SSASLogging
数据库和模型中的'r.TimeStamp'类型是什么? – MarcinJuraszek 2013-03-15 07:07:07
数据库中的类型为DateTime,包中的类型为DateTime。我不确定你的模型是什么意思? – 2013-03-15 07:13:32
您是否可以从'r.TimeStamp'中选择所有日期的列表,而不指定'Max()'? – MarcinJuraszek 2013-03-15 07:17:24