Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
Entre para seguir isso  
nldj

PHP Abrir duas conexões simultaneamente

Recommended Posts

Atualmente uso ADO para conectar o PHP com meu bd MS-SQL 
 

$conn = new COM ("ADODB.Connection") or die("Nâo foi possível carregar o ADO"); 
$connStr = "PROVIDER=SQLNCLI10;SERVER=".$dbhost.";UID=".$user.";PWD=".$password.";DATABASE=".$db; 
$conn->open($connStr); 



******************************************* 

Para a consulta utilizo a seguinte instrução: 
 

$sql = "select * from tabela "; 
$rs = $conn->execute($sql); 
if(!$rs->EOF){ 
while (!$rs->EOF){ 
$rs->MoveNext(); 
} 
} 
$rs->Close(); 
$rs = null; 


******************************************* 

No entanto, preciso fazer um select union utilizando tabelas distintas de banco de dados diferente: 
 

$sql = "select email banco1.dbo.tabela "; 
$sql = $sql . "union "; 
$sql = $sql . "select email banco2.db o.tabela "; 


******************************************* 

Eu gostaria de saber como faço para estabelecer duas conexões simultaneamente e instanciar a consulta de dois bancos na mesma instrução SQL???

Editado por DiF

Compartilhar este post


Link para o post
Compartilhar em outros sites

@nldj Na verdade você não pode usar na mesma instrução sql.

 

Você pode abrir quantas conexões quiser e em bancos diferentes.

 

O você você pode fazer é duas conexões, duas consultas  e mesclar os resultados em um array.

Depois disso, você escolhe um dos bancos e cria uma tabela espelho contendo os dados de ambos bancos de dados.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Valeu @DiF

 

Se entendi bem, você sugere que faça isso:

$conn = new COM ("ADODB.Connection") or die("Nâo foi possível carregar o ADO");
$connStr = "PROVIDER=SQLNCLI10;SERVER=".$dbhost.";UID=".$user.";PWD=".$password.";DATABASE=".$db;
$conn->open($connStr);

$sql = "select email banco1.dbo.tabela ";  
$rs = $conn->execute($sql);  
if(!$rs->EOF){  
	while (!$rs->EOF){  
		$array1[] =  $rs->fields["email"]->value;	
	$rs->MoveNext(); 
	}  
}  
$rs->Close();  
$rs = null; 
$conn2->Close();
$conn2 = null;

$conn2 = new COM ("ADODB.Connection") or die("Nâo foi possível carregar o ADO");
$connStr2 = "PROVIDER=SQLNCLI10;SERVER=".$dbhost2.";UID=".$user2.";PWD=".$password2.";DATABASE=".$db2;
$conn2->open($connStr2);

$sql2 = "select email banco2.dbo.tabela ";  
$rs2 = $conn2->execute($sql2);  
if(!$rs2->EOF){  
	while (!$rs2->EOF){  
		$array2[] =  $rs2->fields["email"]->value;		
	$rs2->MoveNext(); 
	}  
}  
$rs2->Close();  
$rs2 = null; 
$conn2->Close();
$conn2 = null;

 

e depois juntar o resultado tudo num array...certo?

 

o problema é que eu não gostaria de repetir os dados, e para isso eu precisaria de uma instrução na mesma query..

 

por ex:

$sql = "select email banco1.dbo.tabela "; 
$sql = $sql . "where email not in "; 
$sql = $sql . "( "; 
$sql = $sql . "select email banco2.dbo.tabela "; 
$sql = $sql . ") "; 
$sql = $sql . "group by email "; 

só que para isso, eu precisaria instanciar a consulta dos dois bancos na mesma instrução SQL.

 

Se eu criar uma tabela espelho em um único banco contendo os dados de ambos, não vou conseguir instanciar a consulta dos dois bancos na mesma instrução SQL para trazer o resultado que quero.

 

 

Editado por nldj

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Entre para seguir isso  





Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×