quinta-feira, 9 de janeiro de 2025

Seu primeiro código de Machine Learning

Se você está começando a se interessar em Machine Leraning e gostaria de fazer um "Hello World", chegou ao lugar certo. Nesse post vamos utilizar a linguagem Python para criar um modelo para  classificar flores usando o famoso conjunto de dados Iris.

Sem muita lenga lenga, vamos colocar a mão na massa.

Primeiro vamos importar as bibliotecas e carregar o conjunto de dados:

=============================================================

# Importando bibliotecas from sklearn.datasets 

from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split 
from sklearn.ensemble import RandomForestClassifier 
from sklearn.metrics import accuracy_score

# Carregar o conjunto de dados Iris

iris = load_iris() 
X = iris.data
y = iris.target

=============================================================

Depois vamos dividir o conjunto de dados em 2 partes, uma para treinar o modelo e outra para testar o modelo:

=============================================================

# Dividindo o conjunto de dados em treino e teste

X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)

=============================================================

Agora com os o conjunto de dados dividido, vamos criar um modelo de Random Forest e treinar.

=============================================================

# Criar o modelo de Random Forest

model = RandomForestClassifier(random_state=42

# Treinar o modelo 

model.fit(X_train, y_train)

=============================================================

Com isso nosso modelo já está apto para fazer previsões:

=============================================================

# Fazer previsões

y_pred = model.predict(X_test)

# Avaliar a precisão do modelo

accuracy = accuracy_score(y_test, y_pred) 

# Mostrar resultados

print(f"Precisão do modelo: {accuracy:.2f}")
print("Classes previstas para o conjunto de teste:", y_pred)
print("Classes reais do conjunto de teste:", y_test)

=============================================================

Como rodar este código:

  1. Certifique-se de ter Python instalado.
  2. Instale o scikit-learn com pip install scikit-learn.
  3. Cole o código em um arquivo .py ou use um ambiente como Jupyter Notebook.
  4. Execute o arquivo.

Conclusão

Com poucas linhas de código é possível começar a brincadeira com Machine Learning, esse é só o ponto de partida, hoje em dia tem muito conteúdo disponível na internet para aprender mais sobre o assunto e quem sabe seguir essa carreira tão legal e promissora.

Espero ter ajudado alguém, e até mais...

quarta-feira, 8 de janeiro de 2025

Desvendando o Machine Learning: Um Guia para Iniciantes

 Você já se perguntou como funcionam os carros autônomos, como as redes sociais sabem o que você quer ver ou como as assistentes virtuais entendem o que você fala? A resposta para essas perguntas está no Machine Learning, uma área fascinante da tecnologia que está mudando o mundo.

Neste artigo, vamos explorar o que é Machine Learning, como ele funciona e exemplos práticos que mostram sua aplicação no dia a dia.

O que é Machine Learning?

Machine Learning, ou Aprendizado de Máquina, é um campo da inteligência artificial (IA) que permite que sistemas aprendam e melhorem automaticamente com a experiência, sem serem explicitamente programados. Isso significa que, em vez de depender de regras codificadas manualmente, os computadores usam dados para identificar padrões, fazer previsões e tomar decisões.

Existem três principais categorias de Machine Learning:

Aprendizado Supervisionado: O sistema é treinado com dados rotulados. Por exemplo, ensinar um modelo a classificar e-mails como "spam" ou "não spam".

Aprendizado Não Supervisionado: O sistema analisa dados não rotulados para encontrar padrões. Por exemplo, agrupar clientes com base em comportamentos semelhantes.

Aprendizado por Reforço: O sistema aprende através de tentativa e erro, recebendo recompensas ou penalidades. É usado em robótica e jogos.

Como Machine Learning Funciona?

O processo de Machine Learning pode ser dividido em etapas principais:

Coleta de Dados: Tudo começa com a obtenção de dados relevantes.

Preparar os Dados: Isso inclui limpar, organizar e transformar os dados para torná-los utilizáveis.

Escolher um Modelo: Selecionar o algoritmo certo com base no problema (por exemplo, regressão linear, redes neurais ou árvores de decisão).

Treinar o Modelo: Usar dados para ensinar o modelo a fazer previsões.

Avaliar o Modelo: Testar a precisão do modelo com novos dados.

Melhorar o Modelo: Ajustar parâmetros e treinar novamente para obter melhores resultados.

Exemplos de Machine Learning na Prática

Aqui estão alguns exemplos que mostram como o Machine Learning impacta nossas vidas:

Assistentes Virtuais: Como Alexa, Siri e Google Assistant, que usam processamento de linguagem natural para entender comandos de voz.

Diagnóstico Médico: Sistemas de aprendizado de máquina ajudam a identificar câncer em imagens de raio-X com alta precisão.

Reconhecimento Facial: Tecnologias que identificam rostos em fotos ou vídeos, usadas em segurança e redes sociais.

Carros Autônomos: Veículos que tomam decisões em tempo real com base em sensores e câmeras.

Previsão de Fraudes: Bancos e empresas usam Machine Learning para detectar transações suspeitas.

Por que aprender Machine Learning?

Machine Learning é uma das áreas mais promissoras da tecnologia. Com o crescimento de dados e poder computacional, as oportunidades são praticamente ilimitadas. Aprender Machine Learning pode levar a uma carreira empolgante e bem remunerada em setores como tecnologia, saúde, finanças e muito mais.

Para iniciantes, aqui estão algumas dicas:

Comece aprendendo uma linguagem de programação como Python, muito usada em Machine Learning.

Explore bibliotecas e ferramentas populares como TensorFlow, PyTorch e scikit-learn.

Experimente com projetos simples, como criar um modelo para prever preços de casas.

Conclusão

Machine Learning está transformando o mundo e criando soluções inovadoras para problemas complexos. Seja você um entusiasta da tecnologia ou um profissional em busca de uma nova área de especialização, aprender Machine Learning é um passo emocionante.

Pronto para começar? Explore tutoriais, cursos e desafios de aprendizado de máquina. O futuro da tecnologia está em suas mãos!



terça-feira, 7 de janeiro de 2025

Explorando o Mundo da Data Science: Um Guia para Iniciantes

Se você é curioso sobre como as empresas tomam decisões inteligentes baseadas em dados ou como as recomendações de filmes e músicas funcionam, bem-vindo ao mundo da Data Science! Este campo incrivelmente dinâmico combina matemática, estatística, ciência da computação e criatividade para extrair conhecimento e insights a partir de dados.

Neste post, vamos explorar o que é Data Science, como ela está mudando o mundo ao nosso redor e exemplos práticos que mostram sua aplicação em nosso dia a dia.

O que é Data Science?

Data Science, ou Ciência de Dados, é um campo interdisciplinar que utiliza dados para resolver problemas complexos e responder perguntas importantes. Ela abrange a coleta, organização, análise e interpretação de grandes volumes de informação.

Uma das principais características da Data Science é sua flexibilidade. Dependendo do problema, você pode usar técnicas de:

  • Estatística: Para entender tendências e padrões.

  • Machine Learning: Para criar modelos preditivos automatizados.

  • Visualização de Dados: Para apresentar insights de forma clara e impactante.

Exemplos de Aplicações da Data Science

  1. Saúde: Modelos de Data Science ajudam médicos a prever surtos de doenças, diagnosticar com maior precisão e personalizar tratamentos.

  2. E-commerce: Ferramentas baseadas em dados analisam seu histórico de compras e comportamento online para oferecer produtos que você pode estar interessado em adquirir.

  3. Entretenimento: Plataformas como Netflix e Spotify usam algoritmos para sugerir filmes e músicas que você provavelmente vai adorar.

  4. Esportes: Times utilizam análise de dados para criar estratégias vencedoras e avaliar o desempenho dos jogadores.

Por que aprender Data Science?

Data Science não é apenas uma tendência; é uma habilidade essencial em um mundo cada vez mais orientado por dados. Aprender Data Science pode abrir portas para uma carreira empolgante, seja em tecnologia, marketing, finanças, saúde ou mesmo em áreas criativas.

Para iniciantes, é importante começar com o básico:

  • Familiarize-se com linguagens de programação como Python ou R.

  • Aprenda estatística e probabilidade para entender as bases matemáticas.

  • Pratique com projetos simples, como análise de dados de vendas ou criação de visualizações.

Conclusão

Data Science é uma ferramenta poderosa que permite transformar dados brutos em soluções reais para problemas complexos. Se você tem curiosidade e vontade de aprender, este campo oferece infinitas possibilidades de crescimento pessoal e profissional.

Pronto para dar o primeiro passo? Comece explorando recursos gratuitos online, como cursos, blogs e desafios de análise de dados. O mundo da Data Science está esperando por você!





quinta-feira, 8 de agosto de 2013

XML no SQL Server


O método escolhido pelo SQL Server 2000 para permitir modificações em dados usando documentos XML é usando o data source OPENXML. Esta função prove a visualização dos dados em rowset.
Para usar o data source XML com T-SQL, o documento precisa ser validado e armazenado na memória em uma representação de árvore. Esta árvore representa as informações de cada nodo que o SQL Server 2000 terá que saber para preparar a linha de leitura.
No SQL Server 2000 existe uma stored procedure, chamada sp_xml_preparedocument, que irá converter o documento XML para ser representado internamente pelo SQL Server 2000.

SP_XML_PREPAREDOCUMENT


O OPENXML não pode trabalhar com uma string formatada em XML. O OPENXML vai ler os dados já devidamente formatados, pode ele não interpreta a estrutura de nodos. Por este motivo usamos o SP_XML_PREPAREDOCUMENT para converter o documento em um padrão que o SQL Server 2000 possa ler e interpretar.
Esta stored procedure cria uma representação temporária na memória com o formato de uma view.
A figura abaixo exibe uma estrutura de um documento XML usado em nosso exemplo.














Já a figura abaixo mostra como o SQL Server lê as informações depois que o documento passar pela stored procedure SP_XML_PREPAREDOCUMENT.










Segue a baixo o codigo para fazer a importação dos dados.

O código abaixo mostra como fazer uma importação do conteúdo XML para dentro de uma tabela temporária chamada #funcionario, a partir desta tabela é só copiar os dados de uma tabela do SQL Server para outra tabela. Não existe mistério nisso.

Segue durante o código o comentário de cada linha e comandos do SQL Server. 
















































Observação: nunca esqueça que é muito importante remover o conteúdo do documento XML da memória. 

bom pessoal espero que tenha ajudado alguém, e como sempre !!

clica, clica, clica...rsrsrs

segunda-feira, 22 de julho de 2013

Cursores SQL Server

Boa tarde a todos,
vamos aprender hoje um pouco sobre cursores no SQL Server, uma ferramenta muito boa, que soluciona varios problemas, mas dependendo da situação pode ser custosa, então antes de usar analise bem se é realmente necessário.

Entendendo os Cursores


O SQL Server suporta dois tipos de cursores: os cursores T-SQL e os cursores API (Application Programming Interface). Neste artigo falarei dos cursores do tipo T-SQL, isso porque para utilizarmos um cursor API teremos que ter a documentação apropriada de cada API que será utilizada, ou seja, os cursores do tipo API são específicos de cada API.

Os cursores T-SQL são criados usando o comando DECLARE CURSOR. Quando estamos utilizando um cursor a partir de uma aplicação conectada a um servidor Microsoft SQL Server, cada operação no cursor requer uma viagem de ida e volta através da rede.

O conjunto de linhas para o qual um cursor aponta é definido pelo comando SELECT. Existem algumas restrições SELECT ao se criar um cursor T-SQL:

. Não poderá retornar vários conjuntos de linhas.

. Não poderá conter a cláusula INTO para criar uma nova tabela.

. Não poderá conter a cláusulas COMPUTE ou COMPUTE BY, contudo poderá conter funções agregadas, tais como AVG.

Vamos analisar algumas características dos cursores e para não confundir muito dividirei em três grupos de cursores pelas suas características:

. Capacidade de refletir alterações em dados subjacentes.

. Capacidade de rolar pelo conjunto de linhas.

. Capacidade de atualizar o conjunto de linhas.

Refletindo alterações

Se criarmos um cursor com a instrução abaixo:

SELECT * FROM rg_cidade WHERE nmcidade LIKE '%i%'

O banco de dados irá retornar algo similar à imagem abaixo.


                                 Imagine se alguém alterar a linha do registro ‘Farroupilha’ o que acontecerá com o conjunto de dados
apontados pelo cursor?

Existem dois tipos de reflexos que podem ser determinados separadamente quando você criar o seu cursor:


. Alterações nas quais as linhas estejam incluídas no conjunto

. Alterações nos valores das linhas subjacentes.

Rolagem

Outra característica é se você poderá utilizar o cursor para rolar para frente e para trás ou somente para frente. Aqui encontraremos o velho dilema velocidade X flexibilidade. Os cursores que vão apenas para frente são significativamente mais rápidos, mas menos flexíveis.

Atualização

Por último, é se as linhas podem ser atualizadas pelo cursor. Mais uma vez, os cursores de somente leitura geralmente são mais eficientes, porem menos flexíveis.

Tipo de cursor

O T-SQL suporta quatro tipos de cursor diferentes:

. Static

. Keyset

. Dynamic

. Firehose

Cada tipo de cursor armazena os dados de maneira diferente e cada um suporta diferentes tipos de combinações de características descritas anteriormente. Veja a descrição de cada tipo de cursor abaixo:

Static: os cursores static fazem uma cópia dos dados especificados pela instrução SELECT e a armazena no banco de dados tempdb. Este tipo de cursor não permite alterações nos valores de associação ou dados, como qualquer atualização refletiria apenas uma cópia, este tipo é sempre somente leitura. Static podem, contudo ser declarados como forward-only (apenas para frente) ou scrollable (roláveis).

Keyset: um cursor keyset copia para o tempdb apenas as colunas necessárias para identificar exclusivamente cada linha. Para declarar um cursor deste tipo, cada tabela envolvida na instrução SELECT de definição deverá ter um índice exclusivo que defina o conjunto de chaves a ser copiado.

Os cursores keyset podem ser updatable (atualizáveis) ou read-only (somente-leitura) e também scrollable (roláveis) ou forward-only (apenas para frente).

Um cursor keyset é fixado quando você declara o cursor. Se uma linha que satisfaça as condições selecionadas for adicionada enquanto o cursor estiver aberto ela não será adicionada ao conjunto de dados.

Embora a associação na definição do cursor seja fixada quando você abre o cursor, as alterações aos valores de dados nas tabelas subjacentes geralmente são refletidas. Por exemplo, as alterações para o valor nmcidade da linha “Farroupilha” seriam retornadas pelo cursor. As alterações para os valores definidos por chaves, contudo refletirão no cursor apenas se forem feitas pelo cursor. Para continuar o exemplo anterior, se o valor fosse alterado pelo cursor, este retornaria, então, o valor alterado. Porém, se a alteração fosse feita por outro usuário, este cursor continuará retornando o valor anterior.

Dynamic: um cursor dynamic comporta-se como se uma instrução SELECT fosse lançada novamente sempre que uma linha fosse referenciada. Os cursores Dynamic refletem as alterações de valor tanto da associação quanto dos dados subjacentes, quer essas alterações tenham sido feitas pelo cursor ou por qualquer outro usuário.

Firehose: Esse tipo de cursor é declarado usando FAST_FORWARD, mas é mais conhecido como um cursor firehose. Existem duas restrições importantes quanto ao seu uso.

. Se a instrução SELECT que define o cursor faz referencia a colunas do tipo text, ntext ou image e contiver a cláusula TOP, o SQL Server converterá o cursor firehose em um cursor keyset.

. Se a instrução SELECT combinar tabelas que contenham triggers o cursor será convertido para static.

Criando cursores

Para criar um cursor, utilizamos a instrução DECLARE CURSOR. A sintaxe da instrução DECLARE CURSOR copiada do Books Online é:  
                          Veja abaixo a explicação para cada linha da instrução acima:

01. É usado para definir o escopo do cursor assim como funciona em tabelas temporárias (@local ou @@global).

02. Indica a rolagem a ser definida para o cursor e aceita as palavras-chaves: FORWARD_ONLY e SCROLL.

03. Usado para definir o tipo do cursor a ser criado: STATIC, KEYSET, DYNAMIC e FAST_FORWARD.

04. Indica o tipo de bloqueio, se as linhas poderão ser atualizadas pelo cursor e, se assim for, se outros usuários também poderão atualizá-los.

05. Este parâmetro instrui o SQL Server para enviar uma mensagem de aviso para o cliente se um cursor for convertido do tipo especificado em outro tipo.

06. Específica às linhas a serem incluídas no conjunto do cursor.

07. Este parâmetro é opcional, por padrão os cursores são atualizáveis a não ser que o parâmetro de bloqueio seja READ_ONLY. Neste parâmetro podem-se especificar as linhas que permitem a atualização. Se forem omitidas todas as colunas na instrução serão atualizáveis.

Variáveis de cursor

O T-SQL permite declarar variáveis do tipo CURSOR. A sintaxe DECLARE padrão não cria o cursor, para isso use o SET a variável explicitamente. Este tipo de sintaxe é útil quando desejamos criar variáveis que possam ser atribuídas a diferentes cursores, o que poderá fazer se criar um procedimento genérico que opere em vários conjuntos de resultados.

Abrir um cursor

A declaração de um cursor cria um objeto cursor, mas não cria o conjunto de linhas que serão manipuladas pelo cursor. O conjunto do cursor não será criado até que se abra o cursor.

OPEN [GLOBAL] cursor_ou_variável

Feche um cursor

Após ter terminado de usar um cursor, devemos fechá-lo. A instrução CLOSE libera os recursos usados para manter o conjunto do cursor e também liberta quaisquer bloqueios que tenham sido colocados nas linhas se tiver usado parâmetros como: SCROLLOCKS.

CLOSE [GLOBAL] cursor_ou_variável

Desalocar um cursor

Na seqüência de criação de um cursor o DEALLOCATE é o último comando. Sua sintaxe é parecida com os comandos anteriores:

DEALLOCATE [GLOBAL] cursor_ou_variável

Este comando remove o identificador do cursor e não o cursor ou variável. O cursor não será removido até que os identificadores sejam desalocados ou fiquem  fora do escopo.   Manipulando linhas com um cursor

O T-SQL suporta três comandos diferentes para trabalhar com cursores: FETCH, UPDATE e DELETE.

O comando FETCH recupera uma linha especifica do conjunto do cursor. Em sua forma mais simples, o comando FETCH possuí a seguinte sintaxe:

FETCH cursor_ou_variável

Um comando FETCH simples

Abaixo veremos um cursor criado para retornar o primeiro registro da tabela de cidades.

                                                       Podemos também utilizar o FETCH para armazenar o resultado em uma variável utilizando o FETCH cursor INTO variavél. Veja o exemplo a baixo:
































Além disso, podemos utilizar o FETCH para com uma combinação de palavras chaves, por exemplo:


. FETCH FIRST – retorna a primeira linha da variável.

. FETCH NEXT – retorna a linha seguinte.

. FETCH PRIOR – retorna a linha anterior.

. FETCH RELATIVE n – retorna a linha n.

. FETCH ABSOLUNT n – pode especificar linhas antes da linha atual.

FETCH NEXT com um cursor firehose  
                                                                    Atualizando linhas com um cursor

Desde que o cursor seja atualizável, alterar os valores subjacentes em um conjunto do cursor é bastante simples. Vejamos o exemplo abaixo:  
                                                          Observe que este script irá retornar duas consultas, uma com o valor inicial do cursor e outro é o SELECT depois do UPDATE.

Monitoramento dos cursores

O T-SQL fornece duas variáveis globais e uma função para auxiliar a compreender o que está acontecendo com os cursores, @@CURSOR_ROWS que retorna o número de linhas no cursor aberto por último pela conexão, abaixo veremos uma tabela com os valores que podem ser retornados pela @@CURSOR_ROWS.   -m O cursor ainda não foi completamente preenchido.

-1 O cursor é dinâmico e o número de linhas pode variar.

0 Ou nenhum cursor foi aberto ou o mais recente não foi fechado e liberado ou o cursor contem 0 linhas.

N O número de linhas no cursor.

@@FETCH_STATUS retorna informações sobre o último comando FETCH que foi lançado, a tabela baixo mostra os valores de retorno para @@FETCH_STATUS.   0 O FETCH foi realizado com sucesso.

-1 O FETCH falhou.

-2 O registro trazido foi perdido.

CURSOR_STATUS é uma função T-SQL que possuí a seguinte sintaxe:

CURSOR_STATUS (tipo, cursor_ou_variável)

O tipo pode ser: local, global ou variable. Os resultados da função seguem  na tabela abaixo:

1 Se a função for chamada para um cursor dynamic, o conjunto do cursor possuirá zero, uma ou mais linhas. Se a função for chamada para outro tipo de cursor, ela possuirá ao menos uma linha.


0 Conjunto de cursores está vazio.

-1 O cursor está fechado.

-2 É retornado apenas para as variáveis de cursor. Ou o cursor atribuído à variável especificada está fechado ou nenhum cursor foi atribuído à variável ainda.

-3 O cursor ou variável de cursor especificada não existe.

Bom, por hoje é isso pessoal, espero que tenham gostado e que tenha ajudado alguém.   se ajudou, da uma clicadinha nos anuncios ai...rsrsrs   fui...

terça-feira, 25 de junho de 2013

Usando NOLOCK no SQL SERVER

Fala pessoal,
ando meio ocupado depois da mudança de emprego, então dei uma parada de postar, mas hoje separei um conteudo para publicar...vamos lá.

Para um melhor entendimento de todos e contextualização do uso de NOLOCK dentro do Microsoft SQL Server é interessante passarmos antes por algumas definições.
O LOCK é um mecanismo usado pelo Banco de Dados para bloquear conteudo na tentativa de sincronizar os múltiplos acessos de diversos usuários à mesma informação.
O uso do lock está diretamente ligado ao controle de concorrência. Este controle pode ser classificado como otimista ou pessimista. No caso do SQL Server, ele possui suporte a ambos, no entanto, o pessimista é o padrão.

Controle de Concorrência Otimista (Optimistic Concurrency Control)

No controle de concorrência otimista, o usuário não cria Locks quando faz a leituras dos dados. Desta forma, quando o usuário for atualizar dados, o sistema verifica se outro usuário está alterando os mesmos dados. Caso positivo, um erro será gerado. O controle é chamado de controle otimista porque é principalmente utilizado em ambientes onde a disputa dos dados é baixa e o custo de ocasionais Rollbacks das transações é menor do que o custo de utilizar Locks em comandos de leitura.

Controle de Concorrência Pessimista (Pessimistic Concurrency Control)

No controle de concorrência pessimista, a base de dados cria Locks que impedem usuários modificarem dados que podem afetar outros usuários de algum modo. No momento em que um usuário faz uma ação, o banco de dados cria um Lock para aquele conteúdo, desta forma, outros usuários ficam impedidos de realizarem ações que conflitem com o Lock até que o primeiro usuário acabe sua transação. O controle é chamado de controle pessimista porque é usado principalmente em ambientes onde a disputa dos dados é alta e o custo da proteção dos dados com Locks é menor do que o custo dos Rollbacks das transações se ocorrerem conflitos.
Com a definição do lock e dos controles de concorrência, fica mais fácil o entendimento do recurso NOLOCK do Microsoft SQL Server.

O NOLOCK permite executar consultas ao banco de dados sem bloquear o conteúdo. Com esta breve descrição é importante a reflexão que o recurso do NOLOCK só faz sentido no uso do Controle de Concorrência Pessimista.
Considerando este cenário, vamos nos aprofundar um pouco mais no recurso NOLOCK do Microsoft SQL Server. Ele possui duas características bem importantes:

1. Permite executar uma instrução SQL sem causar bloqueio da tabela que está sendo lida;

2. Permite ler dados não commitados.

A primeira característica é bem interessante, principalmente quando se busca performance e paralelismo. No entanto, a segunda característica precisa ser bem observada para evitar um uso indevido do NOLOCK e causar problemas no sistema. Diante disto, é muito importante que o desenvolvedor saiba exatamente o que está fazendo quando estiver utilizando o NOLOCK.

Vamos entender a sintaxe para utilização deste recurso. Segue abaixo um exemplo:



– Instrução SQL Normal:

SELECT * FROM NOTA_FISCAL ORDER BY CD_NOTA_FISCAL;



– Instrução SQL com NOLOCK:

SELECT * FROM NOTA_FISCAL WITH (NOLOCK) ORDER BY CD_NOTA_FISCAL;



Vamos agora analisar o uso para uma aplicação com as seguintes características:

1. A tabela de Nota Fiscal é modificada apenas com comandos de INSERT ou DELETE. Nunca UPDATE, pois devido ao negócio da aplicação não existe atualização das Notas.

2. Quem modifica esta tabela é apenas um procedimento de importação que roda através de um scheduler e não permite multi-threads do mesmo tipo. Ou seja, não temos nunca 2 importações de notas fiscais rodando em paralelo, elas ficam em fila se por algum motivo existir uma concorrência.

3. Existem diversas consultas e reports que precisam de acesso rápido a esta tabela de Nota Fiscal.

4. Todos os reports possuem horário de geração.



Diante destas características do sistema, o uso de NOLOCK pode ser recomendado e trazer um beneficio bem interessante a performance das consultas e reports relacionados as notas fiscais.



Vamos entender melhor esta conclusão..



Quando NÃO usamos NOLOCK e estamos no controle de concorrência pessimista, precisamos esperar que os outros procedimentos na tabela acabem para que consultas possam ser realizadas. Desta forma, denegrindo a performance de relatórios que estão rodando em paralelo a procedimentos de importação. No entanto, com o uso do NOLOCK em uma aplicação com as características descritas acima, podemos consultar os dados sem a necessidade de esperar que as importações realmente terminem, pois teremos lá o conteúdo de momento.

O report vai marcar a hora que ele foi gerado e como não são feitos UPDATES nas notas, nunca teremos dados inconsistentes. No pior caso, poderíamos ter uma nota que posteriormente ela seria cancelada (deletada), mas isto é algo comum dentro do negocio da aplicação.



O uso do NOLOCK implica em abrir mão da consistência em nome da melhor concorrência e tem suas aplicabilidades. No entanto, é importante sempre entender bem do negocio da aplicação e utilizá-lo com bom senso para que suas desvantagens não te tragam problemas piores que um problema de performance.

espero ter ajudado alguem com mais esse conhecimento....e não esqueçam da clicadinha basica nos anuncios,  para dar uma insentivada ...rsrs



segunda-feira, 18 de março de 2013

Quebrando String C# (Split + Contains)

Hoje vamos ver 2 métodos c# que juntos podem nos quebrar um galhão quando trabalhamos com arquivos texto ou strings, são eles SPLIT e CONTAINS.
o CONTAINS busca em uma string, um carácter ou palavra especifica, por exemplo encontrar um '|' ou ';' dentro de uma string ( isso parece familiar ? rsrs), e retorna TRUE ou FALSE.
e com o comando SPLIT podemos montar um array de string com essas informações.
por exemplo, se o usuário criou uma lista de e-mails separados com ';' precisaríamos separar os e-mails para adicionar um a um em certos métodos.
exemplo de uso da dupla:

string email = "marcio@hotmail.com;marcio@yahoo.com;marcio@ig.com.br";

if (email.Contains(";"))
{
       string[] emails = email.split(';');
    //agora basta fazer um forech no array e executar o que desejar
}

por hoje é só pessoal

espero que tenham gostado, e não esqueçam da clicadinha no anuncio, curtida no face e comentário...rsrsrsrs

abraços