Construindo uma classe de conexão com banco de dados em C# utilizando design pattern Singleton
Publicado por Claudio Rocha de Jesus (última atualização em 31/10/2009)
[ Hits: 19.004 ]
Homepage: www.zambotecnologia.com.br
Este arquivo contém duas classes de conexão com banco de dados, uma para o banco de dados PostgreSQL e outro para Microsoft SQL Server. As duas classes implementam o design pattern singleton, onde somente pode ser criada uma única instância da classe.
A primeira não utiliza lock e nem lazy initialization já a segunda (MSSQL) implementa.
Para montar a string de conexão utilizei outra classe que passarei em outro post.
/** * Este arquivo contém duas classes de conexão com banco de dados, * uma para o banco de dados PostgreSQL e outro para Microsoft SQL Server. * As duas classes implementam o design pattern singleton, onde somente * pode ser criada uma única instância da classe. * A primeira não utiliza lock e nem lazy initialization já a segunda * (MSSQL) implementa. * * @category Biblioteca * @package DataAccesLayer * @author Claudio Rocha de Jesus <crochadejesus@yahoo.com.br> * @since 0.1 */ using System; using System.Collections.Generic; using System.Linq; using System.Text; using Npgsql; using System.Data.SqlClient; namespace DataAccessLayer { /// <summary> /// Usa padrão Singleton para obter uma única instância do PostgreSQL. /// Utilizando thread-safe sem usar locks e not lazy. /// </summary> public sealed class ConnectPGSQL { //Cria instância da classe internamente private static readonly ConnectPGSQL _Instance = new ConnectPGSQL(); //Construtor privado, não pode ser instanciado diretamente. private ConnectPGSQL() { } public static ConnectPGSQL getInstance() { return _Instance; } public NpgsqlConnection openConnection() { //Utilizando classe que gera string de conexão do xml OpenConfig openPGSQL = new OpenConfig(); string stConnPGSQL = openPGSQL.readDriverPGSQL(); NpgsqlConnection pgsql = new NpgsqlConnection(stConnPGSQL); pgsql.Open(); return(pgsql); } } /// <summary> /// Usa padrão Singleton para obter uma única instância do Microsot SQL Server. /// Utilizando thread-safe usando locks e lazy initialization e o modelo /// Double Check Lock. /// </summary> public sealed class ConnectMSSQL { //Cria instância da classe internamente, inicialmente como nula private static volatile ConnectMSSQL _Instance = null; //Construtor privado, não pode ser instanciado diretamente. private ConnectMSSQL() { } public static ConnectMSSQL getInstance() { if (_Instance == null) { lock (typeof(ConnectMSSQL)) { if (_Instance == null) _Instance = new ConnectMSSQL(); } } return _Instance; } public SqlConnection openConnection() { //Utilizando classe que gera string de conexão do xml OpenConfig openMSSQL = new OpenConfig(); string stConnMSSQL = openMSSQL.readDriverMSSQL(); //Conectando no banco de dados SqlConnection mssql = new SqlConnection(stConnMSSQL); mssql.Open(); return(mssql); } } }
Usando MySQL na linguagem C - Exemplo 5
Usando MySQL na linguagem C - Exemplo 1
Usando MySQL na linguagem C - Exemplo 3
Programa em C++ sistema de dados de produtos e equipamentos de informatica
Nenhum comentário foi encontrado.
Compartilhando a tela do Computador no Celular via Deskreen
Como Configurar um Túnel SSH Reverso para Acessar Sua Máquina Local a Partir de uma Máquina Remota
Configuração para desligamento automatizado de Computadores em um Ambiente Comercial
Como renomear arquivos de letras maiúsculas para minúsculas
Imprimindo no formato livreto no Linux
Vim - incrementando números em substituição
Efeito "livro" em arquivos PDF
Como resolver o erro no CUPS: Unable to get list of printer drivers
[Python] Automação de scan de vulnerabilidades
[Python] Script para analise de superficie de ataque
[Shell Script] Novo script para redimensionar, rotacionar, converter e espelhar arquivos de imagem
[Shell Script] Iniciador de DOOM (DSDA-DOOM, Doom Retro ou Woof!)
[Shell Script] Script para adicionar bordas às imagens de uma pasta