• Telefones de Contato
  • 0-xx-(51) 3717-3796
  • 0-xx-(51) 9627-3434
Comprar Cursos e Video-Aulas Cursos Online com Certificado Comprar Livros Tutoriais e Artigos Foruns de Discussao
 Você está aqui: Principal > Artigos > Windows
  :: Autor: Rodrigo Crespi   :: Site:     www.crespi.pro.br/
  :: Data:  21/06/2005   :: e-mail: rodrigo@crespi.pro.br
CURSOS ONLINE COM CERTIFICADO
Profiss. de Flash
Programação para Web
Corel Draw X4
Profissionalizante de Informática
Projeto de Redes LAN
Curso de MS Project 2007
Curso de Photoshop
Windows Server 2003
Dominando o Linux
Fundam. de Redes TCP/IP
Profission. de Vendas
Profission. de Redes
Gerência Financeira
Hardware
Criação de Sites
Redes Wireless
Gerência de Projetos
SQL Server 2005
LIVROS
Júlio Battisti
Excel
Word
Windows e Linux
Redes
Programação
Certificações Microsoft e...
Banco de Dados
Webdesign
Gráficos e CorelDraw
Segurança
Aplicativos
Carreira e Sucesso Profis...
Cultura e Interesse Geral
Administração e Negócios
Office 2007
Hardware e Montagem
AutoCAD
Finanças e Investimentos
VÍDEO-AULAS
Access
Excel
Word
PowerPoint
Windows
Programação
Concursos Públicos
Banco de Dados
Webdesign
Internet
CAD
Vídeo e Áudio
Programas Gráficos
Administração e Negócios
CURSOS/E-BOOKS
Access
Excel
Word
PowerPoint
Windows
Redes e TCP/IP
Programação
Certificações Microsoft
Concursos Públicos
Banco de Dados
Webdesign
Internet
BrOffice
Linux
CAD
Vìdeo
Formação Pessoal e Profis...
Área Gráfica
Literatura e Outros
Administração e Negócios
Vídeo-Aulas de Word
OFERTAS ESPECIAIS
ASP.NET 3.5 Para Leigos
Desenvolvendo para web ...
Dossiê Hacker
Joomla - Guia do Operad...
MS Project 2007 e Proje...
Terminais sem Hard Disk
Universidade Hacker - 6...
MAIS VENDIDOS
ASP.NET 3.5 Para Leigos
Desenvolvendo para web ...
Joomla - Guia do Operad...
MS Project 2007 e Proje...
Terminais sem Hard Disk
Universidade Hacker - 6...
Criando Sequence com SQL Server

Introdução

Nos dias de hoje a maior parte dos projetos são multiuso e aplicações client/server, onde diversos usuários acessam e alteram os dados ao mesmo tempo. Com aumento das aplicações baseadas em browser, alguns problemas podem ser diagnosticados, um deles é a concorrência de dados.

Descrição do problema

O que é concorrência de dados? Bem, vamos imaginar um cenário hipotético para ilustrar a explicação. Imagine uma aplicação que possui um cadastro de clientes, este cadastro de clientes possui uma tabela nomeada cad_cliente e composta dos campos: codcliente, nomecliente. Onde codcliente é um integer e a primary key da nossa tabela e nomecliente é um varchar(20).

Agora imaginemos que o cliente do nosso banco de dados possui duas secretárias que atendem a todo pais e cadastram clientes a todo tempo. A secretária “A” abre um evento de inserção na tabela de cad_cliente ao mesmo tempo em que a secretária “B”, supondo que ambas fossem salvar ao mesmo tempo os registros, ou que por uma questão de velocidade de hardware as informações de gravação chegassem ao SGBD ao mesmo tempo, como seria definido o campo codcliente? Ok, poderiamos utilizar campos identity (campos auto-incrementáveis como os do MS-Access), porém não é minha intenção aqui discutir qual a melhor prática até porque isso vai depender do projeto, da estrutura e do ambiente. Pode ser uma ótima sugestão para um próximo artigo.

Solução proposta

Uma boa solução é criar uma tabela auxiliar (por exemplo, NumeroSequencial) que conterá o próximo número seqüencial para cada chave de cada tabela. Para cada registro inserido em uma tabela, você necessitará obter um valor da tabela NumeroSequencial e incrementar o número. Este valor deverá ser usado em um (ID) identificador único de registro a ser inserido.

O uso de sequence é uma prática muito comum principalmente em bancos como postgressql, ORACLE e outros, os quais possuem funções especificas para tratamento de seqüenciais. No caso do postgressql o comando Create Sequence cria um gerador de números seqüenciais, que envolve a criação e a inicialização de uma nova tabela com uma única linha.

Esta técnica é um caminho para implementar controle de concorrência de chaves quando não é possível utilizar campos identity. Técnica que também poderá causar problemas de transação, porque irá criar processos de read, lock e update em valores chaves. Teremos que fazer um controle de lock do registro para resolver esses problemas e não criar um lock da página de dados (o que não era possível em versões antigas do SQL Server, por isso muitos analistas afirmam que não é possível fazer controle de chaves concorrentes no SQL Server).

Solucionando o problema

Resolveremos esse problema por meios mecânicos aumentando o número de registros para preencher o tamanho de uma página de dados. Criando campos “dstmp” no formato char que será usado para adicionar o tamanho necessário aos registros até preencher o equivalente a uma página de dados.

Página de dados é a menor área de armazenamento de dados do SQL Server, e preenchendo ela, estaremos provocando o lock (quando for o caso) somente de uma linha, no caso a página de dados que foi ocupada por valores NULL.

No SQL Server 2000 e SQL Server 7.0, isso não é necessário já que nessas versões automaticamente o lock pertence a um registro e não a uma página de dados. (Lembrando que uma página de dados pode conter mais de um registro). Entretanto, o processo ainda pode competir para read, lock e update um valor chave no mesmo registro. Isto pode conduzir para um deadlock. A procedure que segue é usada para obter um identificador para da tabela NumeroSequencial.

Vamos voltar a nossa hipótese, nós temos dois processos no servidor e os dois necessitam inserir um registro em uma cad_cliente. Um processo lê o registro da tabela NumeroSequencial. Em seguida o outro processo também ira ler um registro da tabela NumeroSequencial. O primeiro processo assumira o mesmo Id do segundo já que ambos estão lendo a tabela ao mesmo tempo. Por isso cada um terá que ter um lock de registro, permitindo a os outros processos somente pegar o Id quando uma atualização estiver concluída. Esta situação é chamada de deadlock.

O SQL Server tem um mecanismo que ira matar um dos processos para que um possa continuar. Isso se faz necessário em uma aplicação client/server para evitar a perda de dados. O melhor caminho para tratar um deadlock é utilizar um hint na clausula From que segue no select forçando o SQL Server a criar um lock na clausula update e instantaneamente evitando o compartilhamento do registro. Um lock irá prevenir que outro processo venha a ler e criar locks até que o registro de origem seja completado.

O segundo processo irá esperar o primeiro processo ser concluído, segue a procedure com o tratamento de lock.

Conclusão

Neste artigo procuro mostar uma solução competente para resolver um problema grave de concorrência de dados usando o MS SQL Server, como eu disse no inicio do artigo não é meu propósito ficar discutindo se essa é a melhor ou pior técnica. Mas existem outras soluções, por exemplo: utilizar campos identity (campos auto-incrementáveis), fazer o controle de campos IDs através da aplicação e etc.. A escolha deve ser por conta do DBA ou AD do projeto, afinal cada caso é um caso e cada aplicação tem suas particularidades.


Web site: www.crespi.pro.br

email: rodrigo@crespi.pro.br




CURSOS ONLINE COM CERTIFICADO E SUPORTE
Gerência de Projetos SQL Server 2005 Gerência Financeira Windows Server 2003
MS Project 2007 Photoshop Projeto e Interconexão de Redes LAN Técnico Profissionalizante de Informática
Profissionalizante de Flash      
CURSO EM FORMATO DE VÍDEO-AULA
EXEMPLOS PRÁTICOS PASSO A PASSO COM SOM E IMAGEM
Clique no curso para informações detalhadas
Curso Duração Informações
ACCESS
Vídeo-Aula - Access 2007 - Curso Básico 2h01m Clique aqui
Vídeo-aula - Access 2007 - Tudo Sobre Consultas 2h30m Clique aqui
Vídeo-Aula - Curso Avançado de Access 2003 2h48m Clique aqui
Vídeo-Aula - Curso Básico de Access 2003 2h49m Clique aqui
EXCEL
Vídeo-aula - Criando uma Agenda no Excel 40m Clique aqui
Vídeo-aula - Curso de Macros e Programação VBA no Excel - Avançado 11h27m Clique aqui
Vídeo-aula - Curso de Macros e Programação VBA no Excel - Básico e Int... 13h02m Clique aqui
Vídeo-aula - Excel 2003 - Curso Básico 3h03m Clique aqui
Vídeo-Aula - Excel 2007 - Curso Avançado 2h30m Clique aqui
Vídeo-Aula - Excel 2007 - Curso Básico 2h35m Clique aqui
Vídeo-Aula - Tabelas Dinâmicas Avançadas no Excel 2003 2h Clique aqui
Vídeo-aula - Tudo Sobre Funções Matriciais no Excel 2h30m Clique aqui
Vídeo-Aula - Tudo Sobre Gráficos no Excel 9h Clique aqui
Vídeo-aula interativa: Tudo Sobre Tabelas Dinâmicas no Excel 2003 2h30m Clique aqui
WORD
Vídeo-Aula - Curso Básico de Word 2003 2h14m Clique aqui
Vídeo-aula - Word 2003 Avançado 1h34m Clique aqui
Vídeo-aula - Word 2003 Básico 2h14m Clique aqui
Vídeo-Aula - Word 2007 - Curso Básico 2h23m Clique aqui
POWERPOINT
Vídeo-Aula - Curso Básico de PowerPoint 2003 2h22m Clique aqui
WINDOWS
Vídeo-Aula - Curso Básico de Windows XP 2h36m Clique aqui
Vídeo-Aula - Windows XP - Formatação e Instalação 3h47m Clique aqui
Vídeo-Aula - Windows XP Básico + Intermediário + Dicas Práticas 8h Clique aqui
PROGRAMAÇÃO
Vídeo-Aula - CALCULADORA HP 12C - Curso Prático em 80 Lições 02h30m Clique aqui
Vídeo-Aula - CALCULADORAS HP 50G - 49G/G+ - 48 GII -- Clique aqui
Vídeo-Aula - Curso Completo de Lógica de Programação 22h15m Clique aqui
Vídeo-Aula - Lógica de Programação com VB.NET 14h Clique aqui
CONCURSOS PÚBLICOS
Vídeo-aula - Excel Para Concursos Públicos - Simulados e Provas Coment... 2h Clique aqui
Vídeo-Aula - Matemática Básica - Módulo I 22h Clique aqui
Vídeo-aula - Matemática Financeira - Teoria e Prática 9h10m Clique aqui
Vídeo-Aula - Raciocínio Lógico - Curso Completo e Prático 12h Clique aqui
Vídeo-aula - Série Concursos: Inglês ESAF - Simulados e Provas Comenta... 2h Clique aqui
BANCO DE DADOS
Vídeo-Aula - Dominando o ORACLE - Curso Prático 12h Clique aqui
Vídeo-Aula - MySQL - Curso Completo e Prático 11h30m Clique aqui
Vídeo-aula - SQL Server 2005 - Reporting Services 2h30m Clique aqui
WEBDESIGN
Vídeo-Aula - Criação de Sites - Curso Básico 2h53m Clique aqui
Vídeo-Aula - Criando Blogs Profissionais - Curso Completo 45m Clique aqui
Vídeo-Aula - Criando Sites Dinâmicos Avançados com DreamWeaver CS3, PH... 4h54m Clique aqui
Vídeo-Aula - Criando Sites Dinâmicos com DreamWeaver CS3, PHP e MySQL 4h05m Clique aqui
Vídeo-Aula - Criando uma Loja Virtual com PHP e MySQL - Curso Completo 19h Clique aqui
Vídeo-Aula - Curso Completo de PHP + HTML + CSS 27h35m Clique aqui
Vídeo-Aula - DreamWeaver CS4 - Curso Prático 1h53m Clique aqui
Vídeo-aula - Flash CS3 - Básico e Prático 4h45m Clique aqui
Vídeo-Aula - Flash MX - Curso Básico 2h26m Clique aqui
Vídeo-Aula - HTML - Curso Prático 2h40m Clique aqui
Vídeo-Aula - Tableless - Crie Sites 100% nos Padrões Web 4h10m Clique aqui
INTERNET
DVD: Hardware - Curso Básico 58m Clique aqui
Vídeo-Aula - Curso de Microinformática Prática 4h35m Clique aqui
Vídeo-aula - Curso Prático de Internet 40m Clique aqui
Vídeo-aula - Curso Prático de Outlook Express 55m Clique aqui
CAD
Vídeo-Aula - Curso de Autocad 2D 4h Clique aqui
Vídeo-Aula - Curso de Autocad 3D 3h45m Clique aqui
VÍDEO E ÁUDIO
DVD: Conversão de Formatos Digitais: Áudio e Vídeo 1h26m Clique aqui
Vídeo-Aula - Como Criar Vídeo-Aulas - Curso Prático 1h04m Clique aqui
Vídeo-Aula - Curso de Teoria Musical 1h Clique aqui
PROGRAMAS GRÁFICOS
Vídeo-Aula -  Flash CS4 - Curso Prático 2h19m Clique aqui
Vídeo-Aula - Curso de CorelDraw X4 - Módulo I 3h Clique aqui
Vídeo-Aula - Curso Profissional Photoshop 4h20m Clique aqui
Vídeo-Aula - Fireworks CS4 - Curso Prático 1h35m Clique aqui
Vídeo-Aula - Photoshop CS4 - Curso Prático 4h24m Clique aqui
ADMINISTRAÇÃO E NEGÓCIOS
DVD - Curso de Oratória - Falando em Público sem Medo 2h36m Clique aqui
LIVROS CAMPEÕES DE VENDA NO SITE
Dossiê Hacker
Universidade Project
Loja de Livros

Uma verdadeira especialização em Office, com 6208 páginas de conteúdo que vai do básico ao avançado, detalhadamente explicado e exemplificado. Desde os recursos básicos, passando pelos recursos avançados, pela criação de macros e pela automação de tarefas usando programação VBA.

Apenas: R$ 195,00 (valor do frete já incluído)

CLIQUE AQUI PARA SABER COMO COMPRAR ESTE CD