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.

Rastreador Tag Bluetooth MiTag Android

Configuração e Rastreamento com Mi Tag O vídeo apresenta uma solução de rastreamento de equipamentos por meio de uma tag chamada MiTag, que foi comprada no AliExpress. O comunicador explica que esta tag funciona sem a necessidade de internet ou chip, utilizando a rede Bluetooth de outros celulares próximos para propagar sua localização até o aplicativo no celular do usuário. O vídeo demonstra o processo de configuração inicial da tag com o aplicativo Google Finder Hub, que é o localizador do Google, exclusivo para Android. Por fim, o tutorial também mostra como desinstalar e resetar a MiTag, um processo necessário caso o usuário queira emparelhar o dispositivo com um celular diferente, já que a tag fica bloqueada após a primeira conexão. https://youtu.be/mm1Z5lus7ag ## Funcionalidades Essenciais da Mi Tag As principais funcionalidades da Mi Tag giram em torno da capacidade de rastreamento independente e de longa duração: 1. **Rastreamento Sem Necessidade de Internet ou Chip:...

Comerciante ou Loja que não emite nota fiscal com CPF do consumidor

Aqui vai uma dica para você consumidor. Alguns comerciantes do DF não estão emitindo a nota fiscal com o CPF do consumidor. Essa prática é ilegal, já que existe uma lei desde 2008 obrigando o comerciante a emitir tal documento. A obrigatoriedade da emissão da Nota Fiscal Eletrônica está prevista na cláusula 2ª do Protocolo ICMS 42/2009, alterado pelo Protocolo ICMS 196/2010, que determina a substituição da nota fiscal impressa pela NF-e. A decisão do Confaz foi publicada no Diário Oficial da União em 13 de dezembro passado. ( http://www.fazenda.gov.br/confaz/confaz/protocolos/ICMS/2009/pt042_09.htm ) Se você é uma das pessoas que tem pedido a nota legal e não tem sido atendida, agora você poderá reclamar direto na Secretaria da Fazenda pelo telefone 156 . O consumidor poderá reclamar de estabelecimento que não emitem nota, como também dos que emitem e não enviam o documento a secretaria. Corra atrás! Quando o comerciante emite e envia o documento para a secretaria, todos sa...