0

こんにちは、LinqToSQL を使用してテーブルから最大日時を取得しようとしています。私はすでに同様の質問をしましたが、もう少し具体的なことをしようとしていましたが、誰も助けることができませんでした. 今回は、SSIS パッケージの別の部分にある SQL 実行タスク以外のソリューションを使用してもかまいません。これが私のコード全体です。私は Identity 列を取得しようとしていましたが、機能していませんでした。ToString が適切でない場合は無視してください。最新の CREATED_TIMESTAMP を取得したいだけです

using System;
using System.Data;
using Microsoft.SqlServer.Dts.Runtime;
using System.Windows.Forms;
using System.IO;
using System.Linq;
using System.Data.SqlClient;
using System.Linq.Expressions;
using System.Collections;
using System.Collections.Generic;
using System.Data.Linq.Mapping;
using System.Data.Linq;



namespace ST_663004ffff194a14b84e2291578ada33.csproj
{
    [System.AddIn.AddIn("ScriptMain", Version = "1.0", Publisher = "", Description = "")]
    public partial class ScriptMain : Microsoft.SqlServer.Dts.Tasks.ScriptTask.VSTARTScriptObjectModelBase
    {

        #region VSTA generated code
        enum ScriptResults
        {
            Success = Microsoft.SqlServer.Dts.Runtime.DTSExecResult.Success,
            Failure = Microsoft.SqlServer.Dts.Runtime.DTSExecResult.Failure
        };
        #endregion


            //Strings for connections
            string iFileName; 
            string oFileName;
            string RW;


        public void Main()
        {
            Dts.Variables["latestTableRow"].Value = getLatest();

            MessageBox.Show(getLatest());

            Dts.TaskResult = (int)ScriptResults.Success;

        }// End Main

        public string getLatest()
        {
            string result = "";

            ////temp dummy/defaul date is two days ago
            //DateTime result = new DateTime();   
            //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
                              orderby r.TimeStamp descending
                              select r).Max();
                    result = rs.Errorval.ToString();
                }

                MessageBox.Show(result);

            }

            catch (Exception e)
            {
                MessageBox.Show("Exception in retreiving latest time: " + e.Message + "/n"
                                + e.StackTrace);
            }

            return result;
       }

    }//end partial class


    [Table(Name = "SSASLogging")]
    public class SSASLogging
    {

        private DateTime timeStamp;

        [Column(Name = "CREATED_TIMESTAMP")]
        public DateTime TimeStamp
        {
            get { return this.timeStamp; }
            private set { ;}
        }
    }//End SSASLogging
}
4

1 に答える 1

0

わかりましたこれは動作します

            using (DataContext RWData = new DataContext(RW))
            {
                Table<SSASLogging> records = RWData.GetTable<SSASLogging>();
                var rs = (from r in records
                          select r).Max(r => r.TimeStamp);
                result = rs;
            }
于 2013-03-20T18:17:12.983 に答える