Igara - Nota Fiscal Eletrônica
quinta-feira, 2 de setembro de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos
Trabalhando com CLR: Stored Procedure – Primeiro passo
Por: Paulo Roberto Pereira Junior
[Entre em contato com o autor ]
Profissional capacitado na área de business intelligence e banco de dados, atuante no mercado desde 2002. Formado em Gestão da Tecnologia da Informação, atualmente se especializando em Gestão Estratégica do Conhecimento. Possui experiência em bancos de dados de diversas plataformas, desenvolvimento e infra-estrutura, além de possuir algumas certificações (MCP, MCTS, MCPD, MCITP e MCT). Escreve periodicamente sobre banco de dados no blog http://www.sqlfromhell.com.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  

Trabalhando com CLR: Stored Procedure – Primeiro passo
Publicado em: 20/07/2010

Depois de uma breve introdução sobre SQL CLR, para a nossa primeira funcionalidade da série de artigos sobre SQL CLR, vamos tratar das Stored Procedure (procedimento armazenado), que podem ser utilizadas basicamente para retornar valores, várias consultas e/ou manipular dados no SQL Server.

Depois de criado o projeto SQL CLR, para criarmos uma Stored Procedure com CLR, nós precisaremos adicionar um novo item (“New Item...” ou “Stored Procedure...”) no projeto, determinando também as características básicas deste item, como o nome do arquivo e o template, no casso “Stored Procedure”.

Já com a Stored Procedure adicionada no projeto, partimos para o código da nossa primeira funcionalidade, que é basicamente imprimir um texto qualquer nas mensagens de notificação (como uma chamada ao comando PRINT do SQL).

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure]

    public static void Primeiro()

    {

        SqlContext.Pipe.Send("SQL From Hell!!!");

    }

};

 

E adicionamos o seguinte comando SQL no arquivo script de teste do projeto para executar nossa Stored Procedure.

EXEC Primeiro


Mais informações sobre DEBUG de projetos SQL CLR:
http://sqlfromhell.wordpress.com/2009/10/03/debug-clr

Após o Debug (F5), podemos validar o resultado na caixa de Output do Visual Studio.

O segundo passo para desenvolver nosso procedimento armazenado é a criação de parâmetros, que basicamente consiste na criação de novos parâmetros no método.

using System;

using System.Data;

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure]

    public static void Primeiro(SqlString texto)

    {

        SqlContext.Pipe.Send(texto.ToString());

    }

};

EXEC Primeiro 'SQL From Hell!!!'

 

E após o deploy deste procedimento armazenado, percebemos que o nome do método (ex.: “Primeiro”) também será o nome do procedimento armazenado no banco de dados, assim como os argumentos.

A possibilidade de criarmos sobrecargas uma procedure (dois ou mais métodos com mesmo nome, mas como parâmetros distintos) não é permitida pelo SQL Server, mesmo que seja possível gerar um assembly compilável. Desta forma é recomendado definir nomes adequados para os nomes dos métodos para que não se repitam.

Mas para não ser necessário alterar os nomes dos métodos podemos determinar os nomes das procedures, simplesmente pela customização do atributo SqlProcedure, conforme o exemplo:

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure(Name = "USP_Primeiro")]

    public static void Primeiro(SqlString texto)

    {

        SqlContext.Pipe.Send(texto.ToString());

    }

};

EXEC USP_Primeiro 'SQL From Hell!!!'

 

Que se refletirá no banco de dados, sem necessidade de customização do script SQL de deploy do projeto CLR, conforme demonstrado abaixo:

Mais informações sobre Deploy de projetos SQL CLR:
http://sqlfromhell.wordpress.com/2010/05/15/publicando-assemblies-clr-no-sql-server-pelo-visual-studio

Assim como podemos customizar o nome dos procedimentos armazenados, também é possível customizar algumas características dos parâmetros do método por meio de atributos (ex.: SqlFacet), conforme demonstrada abaixo a definição da quantidade máxima de 40 caracteres do parâmetro “texto”:

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure(Name = "USP_Primeiro")]

    public static void Primeiro

        ([SqlFacet(MaxSize = 40)]SqlString texto)

    {

        SqlContext.Pipe.Send(texto.ToString());

    }

};

 

EXEC USP_Primeiro 'SQL From Hell!!!'

 

E como resultado, novamente sem qualquer customização no script SQL de deploy:

Desta forma, também será possível tratar as características dos tipos decimais (ou numéricos), como no exemplo que determinamos um parâmetro decimal de tamanho 10 (precisão), tendo duas casas após a vírgula (escala).

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure(Name = "USP_Primeiro")]

    public static void Primeiro

        ([SqlFacet(Precision = 10, Scale = 2)]SqlDecimal valor)

    {

        SqlContext.Pipe.Send(valor.ToString());

    }

};

EXEC USP_Primeiro 12345678.90

 

Após o deploy, os valores determinados pelos atributos estarão refletidos no banco de dados, sem qualquer intervenção direta do desenvolvedor no script SQL:

Outras características também podem ser trabalhadas com os atributos, como atributos que recebem valores do procedimento armazenado (OUTPUT):

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure(Name = "USP_Primeiro")]

    public static void Primeiro

        (out SqlString texto)

    {

        texto = new SqlString("Executado");

    }

};

DECLARE @VAR NVARCHAR(4000)

EXEC USP_Primeiro @VAR OUT

PRINT @VAR

 

Ou parâmetros que têm seus valores alterados durante a execução de procedimentos armazenados (INPUT/OUTPUT):

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure(Name = "USP_Primeiro")]

    public static void Primeiro

        (ref SqlString texto)

    {

        SqlContext.Pipe.Send(texto.ToString());

        texto = new SqlString("VALOR 2");

    }

};

DECLARE @VAR NVARCHAR(4000)

SET @VAR = N'VALOR 1'

EXEC USP_Primeiro @VAR OUT

PRINT @VAR

 

Para as duas situações demonstradas anteriormente, o deploy se encarregará de criar estruturas adequadas para os procedimentos armazenados.

Com os procedimentos armazenados também é possível retornar valores inteiros, como detalhado abaixo.

using System;

using System.Data;

using System.Data.SqlClient;

using System.Data.SqlTypes;

using Microsoft.SqlServer.Server;

 

public partial class StoredProcedures

{

    [SqlProcedure(Name = "USP_Primeiro")]

    public static SqlInt32 Primeiro()

    {

        return 333;

    }

};

DECLARE @VAR INT

EXEC @VAR = USP_Primeiro

PRINT @VAR

 

Concluindo este artigo, espero que tenham gostado desta primeira demonstração dos procedimentos armazenados, onde podemos identificar conceitos básicos de como o deploy se comporta com a customização do CLR, e a facilidade de customizar características dos procedimentos armazenados, sem a necessidade de envolvimento direto com o script de deploy.

No próximo artigo, estarei trabalhando as três principais formas de trabalhar com Stored Procedures desenvolvidas em CLR para retornar resultados de consultas ou simplesmente criar um resultado qualquer.







 

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
Ainda não existem comentários sobre este artigo. Seja o(a) primeiro(a)!
Outros artigos do autor Topo
Trabalhando com SQL CLR: Início
Artigos relacionados Topo
Como migrar dados do SQL Server 2008 R2 para o SQL Azure Database através do SSIS
Tipos de conexões do SSIS no SQL Server 2008 R2
Usando Import and Export Wizard no SQL Server 2008 R2
Como encontrar objetos no SQL Server?
Como calcular a massa de dados no SQL Server?
Self-Join X CTE (Common Table Expression)
Importando e Exportando dados com SQL Server Integration Services
Passo a passo para encontrar as querys mais demoradas do Banco de Dados
Dica sobre erro no SQL Server (Senha expirada)
Como criar um Controle de Versão de Procedures, Views e Functions no SQL Server
Criando um CheckList Automático do Banco de Dados
Integrando PowerPivot do SQL Server 2008 R2 com Excel 2010
Comparativo entre o SQL Server e o SQL Azure Database
Gerar XMLs pelo SQL Server
Utilizando File Stream
Utilizando a propriedade Identity Insert e DBCC CHECKIDENT
Criando primeiro DB com SAD (SQL Azure Database) – SQL Server 2008
Conectando ao SAD (SQL Azure Database) – SQL Server 2008
SQL Azure Database (Introdução) – SQL Server 2008
SQLEngine Utilizando Upgrade
Análise de desempenho entre os bancos de dados SQL Sever x Oracle
Uma libertação chamada OLAP
Gerando backup no SqlServer via código - (SqlCommand e DMO)
Função de tratamento de erros (RAISERROR)
Novos tipos de dados date/time no SQL Server 2008
Trabalhando com Linked Server no SQL Server 2005
DMF - Declarative Management Framework no SQL Server 2008
Pivot Table no SQL Server 2000: Criando um cross-tab report
Novos datatypes para Data e Hora – SQL Server 2008
SQL Server 2008: Spatial Data (dados espaciais)
Produtos relacionados Topo
Pacote: Promoção ASP.Net com Banco de Dados (válido somente para pagamento via boleto bancário)
CD/DVD: CD de Treinamento - SQL Server 2005 Reporting Services com Windows Vista Ultimate - Simulados e vídeos
Pacote: Pacote: Explorando banco de dados usando .NET II (3 CDs)
CD/DVD: CD de Treinamento Gerenciando banco de dados usando Visual Studio Team System
E-Book: Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
CD/DVD: CD de Treinamento Introdução a banco de dados com SQL Server 2005 Express
Livro: Microsoft SQL Server 2005 Express Edition - Interativo: Guia Básico
E-Book: E-Book: SQL Server 2000 - Curso Completo (via download)
Livro: SQL - Guia Prático
Livro: Desenvolvendo Macros no Excel
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 2.623
Artigos: 3.020
Cases: 14
Oportunidades: 4.591
Vídeos .Net: 484
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
O que você fará com o Visual Studio 2010?
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
De: R$ 149,70
Por: R$ 99,80
Promoção PHP + MYSQL Intelimax (válido somente para pagamento via boleto bancário)
De: R$ 308,00
Por: R$ 219,00
Promoção Especial Infra
De: R$ 175,95
Por: R$ 136,00
Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
De: R$ 162,00
Por: R$ 89,00
Promoção VSTS (válido somente para pagamento via boleto bancário)
De: R$ 219,00
Por: R$ 146,00
CDs/DVDss
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
Por: R$ 59,00
DVD Curso de CorelDraw X4
Por: R$ 79,90
DVD Curso de Fireworks CS4
Por: R$ 49,90
DVD Curso de Indesign CS4
Por: R$ 55,00
DVD Curso de Efeitos Digitais
Por: R$ 49,90
Livros
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
De: R$ 129,00
Por: R$ 77,40
Foundation FLASH CS3 para Designers
Ciência Moderna
De: R$ 139,00
Por: R$ 83,40
ALGORITMOS O Guia Essencial
Alta Books
De: R$ 64,90
Por: R$ 58,40
Treinamento Prático em Dreamweaver
Digerati Books
Por: R$ 14,95
Estudo Dirigido de Adobe Photoshop CS4 em português - Para Windows
Erica
De: R$ 88,00
Por: R$ 74,80
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Anderson Patricio
Luiz Felipe de Freitas
Marcio Franco
Eric C M Oliveira
Robert Martim
Ramon Durães
Alessandro de Oliveira Faria
Alfred Reinold Baudisch
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
Criando aplicativos para o Orkut
PL/SQL - Procedures e Funções
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
Como configurar Conexão Remota no SQL Server 2005
WCF – Gerenciamento de Instância
Básico de C++: Estrutura de um programa em C++
ASP.NET 2.0 - Explorando o GridView
Tutorial: Desenhando com o Corel Draw