Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Neusa Novaes

Banco de Dados

Recommended Posts

Olá @Neusa Novaes.

 

Esse erro de falha de conexão só pode ser algum dado da conexão que está incorreto.

 

Pelo que vi na documentação da Locaweb, seu host não deveria ser localhost. Veja: https://wiki.locaweb.com.br/pt-br/Informações_de_acesso_ao_banco_MySQL

 

Citar

A cada nova instalação de um Banco de Dados, o host será criado sempre seguindo o padrão "XX.mysql.dbaas.com.br" (onde "XX" será substituído pelo nome do banco de dados), o mesmo não poderá ser alterado.

 

Você precisa saber exatamente esse endereço para colocar no lugar de "localhost". Isso você pode pedir auxílio para o suporte deles, pois é algo simples de se verificar, tendo o devido acesso.

 

Também pode ser óbvio, mas não custa dizer: quando o @BrunoBit pediu que você retirasse a senha, era só para postar aqui no fórum. No seu arquivo a senha precisa estar definida corretamente.

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Matheus Tavares , @EdCesar , @Alaerte Gabriel , @Omar~ , @ESerra 

Rapaziada, vocês fazem ideia de como resolver esse problema?

MySQL said: Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

O código da Neusa ta funcionando normal, testei aqui, mas está dando esse problema de mysql.sock.

@Neusa Novaes Eu infelizmente não tenho o conhecimento necessário ainda pra te ajudar com relação à esse problema, mas essa rapaziada aí que marquei manjam.

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Matheus Tavares ela tava usando esse:

$servidor="afsistem.mysql.dbaas.com.br";

Pelo o que vi no link que você mandou esse seria o padrão correto, só que mesmo assim ainda tava dando o erro:

MySQL said: Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
1 minuto atrás, BrunoBit disse:

Pelo o que vi no link que você mandou esse seria o padrão correto, só que mesmo assim ainda tava dando o erro:

Talvez esteja correto sim, mas ela precisa confirmar no painel da Locaweb. No link que eu postei há uma explicação detalhada de como confirmar essa informação.

Muito provavelmente o problema está em algum(ns) desse(s) dado(s):

$servidor="localhost";
$bancod="afsistem";
$usuario="afsistem";
$senha="";

 

@Neusa Novaes, você precisa preencher esses dados e ver se consegue acessar o banco por aqui: https://phpmyadmin.locaweb.com.br/

Se der certo, é pq os dados estão corretos e o bug está em outra parte do código. Do contrário, algum dado está errado.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Eu coloquei no conect o servidor como a Locaweb falou isto é afsistem.mysql.dbaas.com.br, porem a pagina ficou em branco teria que encontrar a poesia que foi indicada;

 

Veja a pagina

http://www.amorepaixao.com.br/afrecom/consulta.php?codigo=18031a662b4308ab1b20280458c3

 

A pagina que indiquei foi:

http://www.amorepaixao.com.br/amarsempensar1.htm

 

Um abraço

Neusa Novaes

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Erro de socket na conexão, o que pode ocasionar pelo servidor ou mais provável que seja de código.

Não gosto de mysqli, e pouco conheço pra falar a verdade nunca usei desde a muito tempo na época do mysql já havia migrado e me apaixonado por PDO, mas em fim.

A sintaxe completa de conexão mysqli é:

$mysqli = new mysqli($host, $username, $passwd, $dbname, $port, $socket);

 

Então primeiramente tentamos tentar a conexão com o servidor, então crie um arquivo php qualquer.

Coloque isso nele:

<?php
$conn = [
    'host' => 'endereço do banco de dados', 
    'user' => 'login de usuário do banco que pode pelo menos fazer leitura', 
    'pass' => 'login de usuário usado acima', 
    'data' => 'nome do banco de dados para conectar', 
];

$mysqli = new mysqli($conn['host'], $conn['user'], $conn['pass'], $conn['data']);
if ($mysqli->connect_error) {
    die('Error de conexão (' . $mysqli->connect_errno . ')' . $mysqli->connect_error);
} else {
        echo "Conexão foi bem bem sucedida";
}

Então hospede o arquivo e acesse-o para ver o resultado da conexão.

Se a conexão foi bem sucedida. O problema está no código de 1 ou mais arquivos da aplicação que está a mexer. Ao qual notei que é somente escrito no procedural.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Omar eu coloquei no conecta o numero 1 e fiz um outro php com o nome conecta e coloquei os dados que voce escreveu e a mensagem foi Conex�o foi bem bem sucedida

 

Acho que conectou e agora?

Compartilhar este post


Link para o post
Compartilhar em outros sites
9 minutos atrás, Neusa Novaes disse:

Entendi Omar mas em qual php posso colocar esses dados? No conecta?

Pode ser, desde que quando for fazer alguma query requisite esse arquivo no caso conecta.php.

Só remova o return else que diz que a conexão foi sucedida.

20 minutos atrás, Neusa Novaes disse:

Omar eu coloquei no conecta o numero 1 e fiz um outro php com o nome conecta e coloquei os dados que voce escreveu e a mensagem foi Conex�o foi bem bem sucedida

 

Acho que conectou e agora?

Sim é sinal que não há problemas com o servidor e sim com o códigos de seus arquivos.

 

Então vou lhe mostrar uma forma de fazer leitura dos dados no banco (desde que esteja usando a conexão que mostrei pois necessita da classe nativa mysqli):

<?php
$query = "SELECT * FROM afrecom WHERE codigo='{$codigo}'";
$result = $mysqli->query($query);
if ($result->num_rows > 0) {
    while ($row = $result->fetch_assoc()) {
        echo "<p>{$row['codigo']}</p>";
    }
} else {
    echo ("Nada encontrado no banco com query executada");
} 

De acordo com o que mostrou esse código vai fazer uma busca completa na tabela afrecom e vai selecionar o resultado da coluna codigo que seja referente ao resultado da variável $codigo.

Note que só coloquei $row['codigo'] que é o nome da coluna codigo os demais resultados referentes a essa tabela você deve passar aí.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Bem eu fiz conforme voce falou e apareceu a pagina não localizada

 

http://www.amorepaixao.com.br/afrecom/consulta.php?codigo=144e1d5f9dee5482e09e7ba117af

 

Veja se esta certo o que fiz (tirei as senhas)

 

<?php
$conn = [
    'host' => 'afsistem.mysql.dbaas.com.br', 
    'user' => 'afsistem', 
    'pass' => '', 
    'data' => 'afsistem', 
];

$adminmail="neusa@amorepaixao.com.br";
$nome_site = "Amor e Paixão";
$url_site = "http://www.amorepaixao.com.br";
$carac_url='29';
$arq_som="imagine.mid";
$contorno="stripportadanueva.jpg"; // IMAGEM DE CONTORNO
$fundopag="backgrnd.jpg"; // IMAGEM DE FUNDO DA PAGINA
$mysqli = new mysqli($conn['host'], $conn['user'], $conn['pass'], $conn['data']);
$servmail="mail.amorepaixao.com.br";
$emmliv="neusa@amorepaixao.com.br";
$senliv="";
$emmrec="neusa@amorepaixao.com.br";
$senrec="";
<?php
$query = "SELECT * FROM afrecom WHERE codigo='{$codigo}'";
$result = $mysqli->query($query);
if ($result->num_rows > 0) {
    while ($row = $result->fetch_assoc()) {
        echo "<p>{$row['codigo']}</p>";
    }
} else {
    echo ("Nada encontrado no banco com query executada");

Compartilhar este post


Link para o post
Compartilhar em outros sites

Só um palpite, mas deve está apresentado HTML erro 500.

Erro grave de sintaxe de arquivo.

Citar

$senrec="";
<?php // TAG php sendo reaberta dentro o código?
$query = "SELECT * FROM afrecom WHERE codigo='{$codigo}'";

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Neusa Você copiou o código do Omar e abriu 2 tags php sem fechar a primeira.

Corrigi o código, realize um novo teste pra gente ver:

<?php
$conn = [
    'host' => 'afsistem.mysql.dbaas.com.br', 
    'user' => 'afsistem', 
    'pass' => '', 
    'data' => 'afsistem', 
];

$adminmail="neusa@amorepaixao.com.br";
$nome_site = "Amor e Paixão";
$url_site = "http://www.amorepaixao.com.br";
$carac_url='29';
$arq_som="imagine.mid";
$contorno="stripportadanueva.jpg"; // IMAGEM DE CONTORNO
$fundopag="backgrnd.jpg"; // IMAGEM DE FUNDO DA PAGINA
$mysqli = new mysqli($conn['host'], $conn['user'], $conn['pass'], $conn['data']);
$servmail="mail.amorepaixao.com.br";
$emmliv="neusa@amorepaixao.com.br";
$senliv="";
$emmrec="neusa@amorepaixao.com.br";
$senrec="";


$query = "SELECT * FROM afrecom WHERE codigo='{$codigo}'";
$result = $mysqli->query($query);
if ($result->num_rows > 0) {
    while ($row = $result->fetch_assoc()) {
        echo "<p>{$row['codigo']}</p>";
    }
} else {
    echo ("Nada encontrado no banco com query executada");
} 

?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Isso não é um erro, ele deu echo em $row["codigo"], é sinal de que a query funcionou normalmente e não disparou mais aquele erro de mysql.sock.

Compartilhar este post


Link para o post
Compartilhar em outros sites
1 minuto atrás, Neusa Novaes disse:

Mas se voce entrar no phpmyadmin.locaweb esse codigo esta lá, não sei o que acontece.

É por isso mesmo que deu certo, o código conseguiu buscar o dado que ta no seu banco, se o dado buscado não estivesse lá iria disparar o outro echo, que no caso seria:

echo ("Nada encontrado no banco com query executada");

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Realiza um novo teste e copie com calma:

conecta.php

ps: coloque sua senha

<?php
$conn = [
    'host' => 'afsistem.mysql.dbaas.com.br', 
    'user' => 'afsistem', 
    'pass' => '', 
    'data' => 'afsistem', 
];

$adminmail="neusa@amorepaixao.com.br";
$nome_site = "Amor e Paixão";
$url_site = "http://www.amorepaixao.com.br";
$carac_url='29';
$arq_som="imagine.mid";
$contorno="stripportadanueva.jpg"; // IMAGEM DE CONTORNO
$fundopag="backgrnd.jpg"; // IMAGEM DE FUNDO DA PAGINA
$mysqli = new mysqli($conn['host'], $conn['user'], $conn['pass'], $conn['data']);
$servmail="mail.amorepaixao.com.br";
$emmliv="neusa@amorepaixao.com.br";
$senliv="";
$emmrec="neusa@amorepaixao.com.br";
$senrec="";
?>

consulta.php

<?php
/************************************************************************
ARQUIVO .........:AFRECOM 2.0 - Indicador de Mensagens/Sites
BY ..............: Neusa C.Novaes
SITE ............: Amor e Paixao http://www.amorepaixao.com.br
DATA ............: 13/01/2018
Copyright (c) 2004 Neusa C.Novaes.  All rights reserved.
************************************************************************/
date_default_timezone_set('America/Sao_Paulo');
error_reporting(E_ALL ^ E_NOTICE);
$codigo = substr(($_GET['codigo']), 1, 33);
$nramg = substr(($_GET['codigo']), 0, 1);
$ano = date('Y');
$mes = date('n');
$dia = date('d');
$dsemm = date('w');
$hora=getdate();
$dsem[0] = "Domingo";
$dsem[1] = "Segunda-feira";
$dsem[2] = "Ter&ccedil;a-feira";
$dsem[3] = "Quarta-feira";
$dsem[4] = "Quinta-feira";
$dsem[5] = "Sexta-feira";
$dsem[6] = "S&aacute;bado";
$nmes[1] = "janeiro";
$nmes[2] = "fevereiro";
$nmes[3] = "mar&ccedil;o";
$nmes[4] = "abril";
$nmes[5] = "maio";
$nmes[6] = "junho";
$nmes[7] = "julho";
$nmes[8] = "agosto";
$nmes[9] = "setembro";
$nmes[10] = "outubro";
$nmes[11] = "novembro";
$nmes[12] = "dezembro";
$horatual=($hora['hours'].':'.$hora['minutes']);
$data = $dsem[$dsemm].', '.$dia.' de '.$nmes[$mes].' de '.$ano.' - Hora: '.$horatual;
$urlmsg = $_POST;
$datac = date("d/m/Y");
$datah = date("H:i:s");
require_once($_SERVER["DOCUMENT_ROOT"] . "/afrecom/conecta.php");
$query = $mysqli->query("SELECT * FROM afrecom WHERE codigo='$codigo'");
$dadoss = $query->fetch_assoc();   
$mensagem=$dadoss['urlmens'];
$idd=$dadoss['id'];
$nnome=$dadoss['nomerem'];
$nemail=$dadoss['emailrem'];
$amg="nomeamg".$nramg;
$emg="emailamg".$nramg;
$vmmg="visualamg".$nramg;
$visual=$dadoss[$vmmg];
$namigo=$dadoss[$amg];
$eamigo=$dadoss[$emg];
if($visual <> "S"){
$msg1='
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head> <!--estava faltando fechar o head--></head>
<BGSOUND src="'.$url_site.'/afrecom/'.$arq_som.'" loop=infinite>
<META HTTP-EQUIV="Content-Type" CONTENT="text/html;charset=iso-8859-1">
<link href="'.$url_site.'/afrecom/style.css" rel="stylesheet" type="text/css">
<body background="'.$url_site.'/afrecom/'.$fundopag.'" leftmargin="0" topmargin="0" rightmargin="0" bottommargin="0">

<div align="center">
  <table border="7" bordercolor="#808000" bordercolorlight="#FFFF99">
  <tr>
  <td align="center">
    <table border="10" bordercolor="#808000">
    <tr>
    <td>
      <img border="0" src="'.$url_site.'/afrecom/banner1.gif" width="468" height="60">
    </td>  
    </tr> 
    </table> 
  </td> 
  </tr>
</table>
</div>

<p>&nbsp;</p>

<div align="center">
  <table border="15" cellpadding="6" width="90%" bordercolordark="#808000" bordercolorlight="#FFFF99">
  <tr>
  <td width="100%" align="left" class="tabela">
  <i><font color="#ffffff" size="1">Mensagem automática, por favor não responda.<br>'.$data.'</font></i>
  <HR width="100%" color=#ffffff SIZE=1 align="left">
  <br>
  <font color="#ffffff" size="1">Olá &nbsp;'.$nnome.'! </font><br><br>
  A&nbsp;mensagem&nbsp;que&nbsp;você&nbsp;enviou&nbsp;para:&nbsp;
  <br><b>'.$namigo.'</b>&nbsp;&nbsp;e-mail:&nbsp;&nbsp;<b>'.$eamigo.'</b>
  <br>foi&nbsp;visualizada&nbsp;em&nbsp;nossos&nbsp;servidores&nbsp; nesta(e)&nbsp;&nbsp;
  <br><b>'.$data.'</b><br><br>
  <!-- faltava td-->
  </td>
  <!-- faltava tr-->
  </tr>
  </table>
<!--estava faltando esta div-->
</div> 

</body> 
</html> ';

echo $msg1;
}
?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por douglas79
      Bom dia,

      Há alguns dias que venho instalar o apache, o php, mysql e o phpmyadmin manualmente e sem obter sucesso. Até consegui rodar o php, porém, quando vou baixar a úitima versão do MYSQL, não tem todos os pacotes nele instalados, inclusive no completo, só encontro o Router.
      Alguém pode me dizer o porquê que isso está ocorrendo?
      Desde já agradeço a ajuda de vocês, que será bem vinda!
      No aguardo!

      Uso a versão 8.3.9 do PHP
      Meu SO é o Windows 10 32 bits
    • Por landerbadi
      Tenho uma tabela chamada "item" com os seguintes campos: id, name, active. Nela tem cadastrado vários itens. No campo "active" eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo active. E outra tabela chamada "product" com os seguintes campos (id, name) com os seguintes registros: 1, Produto A 2, Produto B 3, Produto C E uma terceira tabela chamada "product_item" com os seguintes campos (productID, itemID). No campo productID eu coloco o id de um produto da tabela "product" e no campo "itemID" eu coloco o id do produto da tabela "item". Exemplo: 1, 1 1, 3 1, 4 2, 3 2, 4 Sendo assim o produto A da tabela 'product" comtem os itens casa, cama e moto. Eu preciso fazer uma busca da seguinte maneira:  Eu escolho um registro da tabela "item", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "product" que contenham a palavra "casa" e que os demais itens estejam ativos no siste. Ou seja, que contenham um "S" no campo "active"  Eu consegui fazer isso da seguinte maneira: SELECT P.id, P.name, GROUP_CONCAT(I.name ORDER BY I.name) AS items FROM product P JOIN product_item PI ON P.id = PI.productID JOIN item I ON I.id = PI.itemID AND I.active = 'S' WHERE P.id NOT IN ( SELECT PI.productID FROM product_item PI JOIN item I ON I.id = PI.itemID WHERE I.active IS NULL ) AND P.id IN ( SELECT PI.productID FROM product_item PI JOIN item I ON I.id = PI.itemID WHERE I.name = 'mesa' ) GROUP BY P.id, P.name; O problema que eu estou tendo é o seguinte:
      Quando eu jogo este código para o banco de dados onde eu já tenho os registros cadastrado o php fica lendo uma eternidade e não lista os produtos.
       
      Usando código no banco de dados que eu fiz para testes ele funciona perfeitamente pois nele tem poucos registros.
       
      No banco de dados principal a tabela "item" tem 11.196 registros. A tabela "product" tem 88.214 registros e a tabela "product_item" tem 518.378 registros. 
       
      Eu acredito que, devido o banco de dados ser muito grande, ele não consegue listar.
       
      Alguém sabe de algum meio de resolver isso?
       
       
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, ativo. Nela tem cadastrado vários itens. No campo ativo eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "produtos" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, mesa, moto 2, mesa, casa, cama 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela produtos da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "mesa". Preciso fazer com que o php me liste todos os registros da tabela "produtos" que contenham a palavra "mesa". Até aqui tudo bem eu consigo listar. Estou fazendo assim: <?php $item = "mesa" $sql = mysqli_query($conn, "SELECT * FROM produtos WHERE item1 LIKE '$item' OR item2 LIKE '$item' OR item3 LIKE '$item' LIMIT 10"); while($aux = mysqli_fetch_assoc($sql)) { $id = $aux["id"]; $item1 = $aux["item1"]; $item2 = $aux["item2"]; $item3 = $aux["item3"]; echo $id . " - " . $item1 . ", " . $item2 . ", " $item3 . "<br>"; } ?> O problema é que está listando todos os registros que contém o item mesa. Eu preciso que o php verifique os demais item e me liste somente os registro em que todos os registros estejam ativos no sistema. No exemplo acima ele não deveria listar o registro 3. pois nesse registro contém o item "radio" e este item não está ativo no sistema. Ou seja, o registro "radio" na tabela itens não possui um "S" na coluna "ativo". Alguém sabe como resolver isso?
    • Por First
      Olá a todos!
       
      Eu estou criando um sistema do zero mas estou encontnrando algumas dificuldades e não estou sabendo resolver, então vim recorrer ajuda de vocês.
      Aqui está todo o meu código: https://github.com/PauloJagata/aprendizado/
       
      Eu fiz um sistema de rotas mas só mostra o conteúdo da '/' não sei porque, quando eu tento acessar o register nada muda.
      E eu também quero que se não estiver liberado na rota mostra o erro de 404, mas quando eu tento acessar um link inválido, nada acontece.
      Alguém pode me ajudar com isso? E se tiver algumas sugestão para melhoria do código também estou aceitando.
       
       
      Desde já, obrigado.
    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.