linq更新无法正常工作

时间:2015-05-19 14:39:39

标签: c# linq

我已经尝试了很多但都徒劳无功。
我编写了一个LINQ代码,但无法保存数据库中的更改 无论是更新记录还是没有错误。

class Program
{
    [Table(Name = "mainframe_replication")]
    public class mainframe_replication
    {
        private string _REPL_GUID;
        [Column(IsPrimaryKey = true, Storage = "_REPL_GUID")]
        public string REPL_GUID
        {
            get { return this._REPL_GUID; }
            set { this._REPL_GUID = value; }
        }

        private string _REPL_TYPE;
        [Column(Storage = "_REPL_TYPE")]
        public string REPL_TYPE
        {
            get { return this._REPL_TYPE; }
            set { this._REPL_TYPE = value; }
        }

        private string _RPT_ID;
        [Column(Storage = "_RPT_ID")]
        public string RPT_ID
        {
            get { return this._RPT_ID; }
            set { this._RPT_ID = value; }
        }

        private string _RPT_VERS;
        [Column(Storage = "_RPT_VERS")]
        public string RPT_VERS
        {
            get { return this._RPT_VERS; }
            set { this._RPT_VERS = value; }
        }

        private string _RPT_BYTES;
        [Column(Storage = "_RPT_BYTES")]
        public string RPT_BYTES
        {
            get { return this._RPT_BYTES; }
            set { this._RPT_BYTES = value; }
        }

        private string _REPL_DTM;
        [Column(Storage = "_REPL_DTM")]
        public string REPL_DTM
        {
            get { return this._REPL_DTM; }
            set { this._REPL_DTM = value; }
        }

        private string _NOTIF_ID;
        [Column(Storage = "_NOTIF_ID")]
        public string NOTIF_ID
        {
            get { return this._NOTIF_ID; }
            set { this._NOTIF_ID = value; }
        }
    }

    public class MyPoco
    {
        public string ReportId { get; set; }
        public string Reportversion { get; set; }
        public string ReportBytes { get; set; }
        public string ReportDate { get; set; }
        public string NotifId { get; set; }
        public string RecipAdd { get; set; }
    }

    public static string loglocation;
    static void Main(string[] args)
    {
        try
        {
            using (DataClasses1DataContext db = new DataClasses1DataContext())
            {
                Table<NOTIF_RECIP> NOTIF_RECIP_alias = db.GetTable<NOTIF_RECIP>();
                Table<NOTIF_SCHED> NOTIF_SCHED_alias = db.GetTable<NOTIF_SCHED>();
                Table<mainframe_replication> mainframe_replication_alias = db.GetTable<mainframe_replication>();

                var ids = NOTIF_SCHED_alias.Select(x => x.NOTIF_RPT_ID).ToArray();

                foreach (string notif_sched_data in ids)
                {
                    var repljoinmf = mainframe_replication_alias
                        .Join(NOTIF_RECIP_alias, mfr => mfr.RPT_ID, nr => nr.NOTIF_RECIP_ID, (mfr, nr)
                            => new MyPoco { ReportId = mfr.RPT_ID, Reportversion = mfr.RPT_VERS, ReportBytes = mfr.RPT_BYTES.ToString(), ReportDate = mfr.REPL_DTM.ToString(), NotifId = mfr.NOTIF_ID, RecipAdd = nr.NOTIF_RECIP_ADDR });

                    foreach (var repljoinmf_data in repljoinmf)
                    {
                        repljoinmf_data.NotifId = "abc";

                        //DO STUFF 
                        //  repljoinmf_data.NotifId = "Changedxyz";
                    }
                    db.SubmitChanges();
                }
            }
        }
        catch (Exception e)
        {
            Console.WriteLine(e.ToString());
        }
    }
}

提交更改时不会出现任何错误 我需要改变什么?
任何建议都会有所帮助。

2 个答案:

答案 0 :(得分:0)

您正在修改MyPoco对象的属性。这只是表格的表示。这就是数据库未更新的原因。

您可以将MyPoco发送给您的客户。它会执行一些更改。然后,您可以重新创建实体并从Poco对象复制属性。然后,您需要将attach修改后的实体添加到您的表中,然后保存更改。

如果您直接修改实体,则无需附加,因为它将保留指向数据库的链接(假设您使用相同的Databasecontext执行此操作)。

答案 1 :(得分:0)

如果要将更改保存回原始数据源,则需要使用实际实体而不是这些实体的投影。由于您要连接两个表,因此一个选项是将这些实例放入匿名类型并更新它们:

foreach (string notif_sched_data in ids)
{
    var repljoinmf = mainframe_replication_alias
        .Join(NOTIF_RECIP_alias, 
              mfr => mfr.RPT_ID, 
              nr => nr.NOTIF_RECIP_ID, 
              (mfr, nr) => new {mfr, nr});

    foreach (var repljoinmf_data in repljoinmf)
    {
        //DO STUFF 
        repljoinmf_data.mfr.NotifId = "Changedxyz";
    }
    db.SubmitChanges();

在上一个问题中,您被告知匿名类型无法提升,但在这种情况下,您将通过匿名类型修改引用的实例。所以你不是要更新匿名类型本身,而只是更新匿名类型所引用的对象。