无法更新提交映射LINQ2SQL

问题描述:

我有现在的烦恼,我不能更新DBDataContext表X,所以这是我的片段,顺便当我更新只是一个表它的作品!但是,当我插入,然后更新,它会抛出异常:“无法从System.Int32投对象System.String类型”无法更新提交映射LINQ2SQL

{ 
      using (DBDataContext db = new DBDataContext()) 
      { 
       int codigo = Convert.ToInt32(lblNroInforme.Content); 
       int sucessfull = 0; 


       INFORMEMEDICO varInf = (from i in db.INFORMEMEDICOs 
             where i.numeroinforme == codigo 
             select i).SingleOrDefault(); 


       if (varInf == null) 
       { 
        varInf = new INFORMEMEDICO(); 
        varInf.codigoclase = Convert.ToInt32(lblCodigoClase.Content.ToString()); 
        varInf.codigoestudio = lblCodigoEstudio.Content.ToString(); 
        varInf.codigopaciente = Convert.ToInt32(lblCodigoPaciente.Content.ToString()); 
        varInf.conclusion = GetText(rtbConclusion); 
        varInf.fechainforme = DateTime.Today; 
        varInf.firmauno = getJPGFromImageControl(firmaUno.Source as BitmapImage); 
        varInf.firmados = getJPGFromImageControl(firmaDos.Source as BitmapImage); 
        varInf.hallazgo = GetText(rtbHallazgo); 
        varInf.horainforme = Convert.ToDateTime(DateTime.Today.ToShortTimeString()); 
        varInf.impreso = 0; 
        varInf.medicoinforma = cboTurnoMed.SelectedValue.ToString(); 
        varInf.nombreinforme = txtNombreExamen.Text; 
        varInf.numeroinforme = Convert.ToInt32(lblNroInforme.Content.ToString()); 
        varInf.tecnica = GetText(rtbTecnica); 
        varInf.turnosocio = lblTurnoMedico.Content.ToString(); 

        try 
        { 
         db.INFORMEMEDICOs.InsertOnSubmit(varInf); 
         db.SubmitChanges(); 
         sucessfull = 1; 
        } 
        catch (Exception ex) 
        { 
         MessageBox.Show("Error : " + ex.Message); 
        } 
        if (sucessfull==1) 
        { 
         EXAMENXATENCION varExA = (from ea in db.EXAMENXATENCIONs 
                where ea.codigo == codigo 
                select ea).SingleOrDefault(); 
         varExA.estadoestudio = 'I'; 
         db.SubmitChanges(); 
        } 

       } 

      } 

     } 

我得到这个堆栈的调试器,当我进行更新:

en System.Data.Linq.IdentityManager.StandardIdentityManager.MultiKeyManager`3.TryCreateKeyFromValues(Object[] values, MultiKey`2& k) 
    en System.Data.Linq.IdentityManager.StandardIdentityManager.MultiKeyManager`3.TryCreateKeyFromValues(Object[] values, MultiKey`2& k) 
    en System.Data.Linq.IdentityManager.StandardIdentityManager.MultiKeyManager`3.TryCreateKeyFromValues(Object[] values, MultiKey`2& k) 
    en System.Data.Linq.IdentityManager.StandardIdentityManager.MultiKeyManager`3.TryCreateKeyFromValues(Object[] values, MultiKey`2& k) 
    en System.Data.Linq.IdentityManager.StandardIdentityManager.IdentityCache`2.Find(Object[] keyValues) 
    en System.Data.Linq.IdentityManager.StandardIdentityManager.Find(MetaType type, Object[] keyValues) 
    en System.Data.Linq.CommonDataServices.GetCachedObject(MetaType type, Object[] keyValues) 
    en System.Data.Linq.ChangeProcessor.GetOtherItem(MetaAssociation assoc, Object instance) 
    en System.Data.Linq.ChangeProcessor.BuildEdgeMaps() 
    en System.Data.Linq.ChangeProcessor.SubmitChanges(ConflictMode failureMode) 
    en System.Data.Linq.DataContext.SubmitChanges(ConflictMode failureMode) 
    en System.Data.Linq.DataContext.SubmitChanges() 
    en Demo.View.InformeMedico.btnGuardar_Click(Object sender, RoutedEventArgs e) en D:\cs_InformeMedico\app\InformeMedico.xaml.cs:línea 430 

了大量的研究后,我发现这个错误只在WinXP机器存在与.NET 3.5 SP1。 在Windows 7上,它工作正常。不幸的是,同一个框架有两种不同的版本。

微软有一个修复程序,它解决了我在xp机器上的问题。 http://support.microsoft.com/hotfix/KBHotfix.aspx?kbln=ja&kbnum=963657

问候, 弗洛里安

+0

那真实的,顺便说一下,我不能弄明白在Windows Vista上机1年前,我会尝试这些天在Windows 7上,请联系:) – 2010-09-02 17:05:53

打开DMBL文件作为一个XML文件。检查每列的类型,看看是否应该是一个int是一个字符串。

+0

检查已:( – 2009-02-16 21:58:52

LINQ to Sql不支持将外键用于唯一键约束(即备用键)。我遇到了同样的问题,并发现阅读一些博客。我认为这不是一个错误。

Non-Primary Keys and LINQ to SQL Problems (is this a bug)?