Pular para o conteúdo principal

LINQ to SQL Concurrency - ChangeConflictException Row not found or changed

ChangeConflictException Row not found or changed Se criarmos um pequeno modelo do banco de dados Northwind, e tentar modificar um dos registro de customer ("ALFKI" por exemplo):

NorthwindDataContext db = new NorthwindDataContext();

Customer alfki = db.Customers.Single(c => c.CustomerID == "ALFKI");

alfki.City = "London";

db.SubmitChanges();

Veremos que a query de atualização gerada em tempo de execução foi:

UPDATE Customers

SET City = 'London'

WHERE CustomerID = 'ALFKI' AND

CompanyName = 'Alfreds Futterkiste' AND

City = 'Berlin' AND

Region IS NULL

Evidentemente, a query de atualização da coluna cidade SET está de acordo com a coluna CustomerID, mas quem são estas condições, na cláusula where?

LINQ para SQL usa Optimistic Concurrency estratégia. Quando os registos são selecionados, não realizar qualquer lock sobre as linhas selecionadas. Só quando ele tenta atualizar os registros no banco de dados ou excluí-los é que ele verifica se os mesmos não foram alterados desde a última consulta. Como é feito? Ele tenta atualizar a linha que coincide com os valores originais, contido no DataContext. Isto explica as condições adicionais na query de atualização.

Se durante a execução a lógica foi finalizada, as atualizações que forem feitas a partir de outro programa (ou outro DataContext), lançara uma exceção:

System.Data.Linq.ChangeConflictException was unhandled
Message="Row not found or changed."
Source="System.Data.Linq"

LINQ para SQL tenta olhar para o registro atualizado e comparar com todas as colunas com seus valores originais, e quando não encontra o registro, a exceção é lançada. Essa é a maneira que o LINQ para SQL nos diz que a linha que estava procurando foi eliminada ou alterada por outro programa e a atualização não pode ser feita.

Artigo original
Guy Burstein's

Comentários

Postagens mais visitadas deste blog

EmguCV DLL Not Found Exception -Unable to find cvextern?

Eu também tive os mesmos problemas. Neste fórum emgucv , não sei por que cvextern.dlldo emgucv 3.4.3 não é possível carregar cvextern (porque não é possível encontrar cvextern), e você permitiu usar o arquivo cvextern.dlldo emgucv 3.4.2 (certifique-se de escolher x64 / x86), copie /bin/Debuge este arquivo é encontrado automaticamente /bin/Debug/x86ou /bin/Debug/x64quando você termina de construir o programa no Visual Studio.  O Erro:  The type initializer for 'Emgu.CV.CvInvoke' threw an exception. : Unable to load DLL 'cvextern': The specified module could not be found. (Exception from HRESULT: 0x8007007E)  Para resolver o problema copia a pasta x64 ou x86 para dentro da pasta bin da aplicação. Ou copie os arquivos para dentro da pasta bin da aplicação WCF.

Vagas .Net - Projeto CNSA

Prezados, Estamos selecionando candidados, em forma de cadastro de reserva, para participar do projeto: Cadastro Nacional de Sociedade de Advogados, na Assessoria de Tecnologia da Informação do Conselho Federal da OAB. Basicamente teremos 3 fases: * Avaliação Curricular; * Entrevista Pessoal; * Verificação prática; Outras informações: Vaga: Desenvolvedor .NET. Quantidade: 3. Tempo: 4 meses. Segue abaixo os requisitos que devem ser atendidos pelo candidato: Conhecimentos básicos * Conhecimento avançado em C#; * Conhecimento em ASP.NET 2.0; * ADO.NET 2.0; * SQL SERVER 2005 (DML, stored procedures, MER); * UML (Interpretação de casos de uso, diagrama de atividades, de classe, de sequência); * Experiência em projetos anteriores com ASP.NET e C#; Desejável * LINQ TO SQL; * Conhecimento em JavaScript e padrões Web (XHTML, CSS, etc); * ASP.NET 3.5; * C# 3.0 (LINQ, Propriedade implementadas automaticamente, Métodos de Extensão, Expressão Lamb...

Lista de IPs DNS Oi nos Estados

As vezes quando colocamos um IP fixo para uma máquina na rede, e esta rede tem acesso a internet através da rede da Oi, bem provável que você não conseguirá acessar a internet. Para resolver o problema defina o DNS primário e Secundário nas propriedades da placa de rede. - Protocolo TCP/IP Versão 4 (TCP/IPv4). Segue lista de DNS por estado. RS 201.10.1.2 201.10.120.3 SC 201.10.120.3 201.10.1.2 PR 201.10.120.2 201.10.128.3 GO 201.10.128.3 201.10.120.3 DF 201.10.128.2 201.10.120.2 MS 201.10.128.3 201.10.1.2 MT 201.10.128.2 201.10.120.3 RO/AC 201.10.128.2 201.10.1.2