Jump to content
wesleycsilva

Consulta

Recommended Posts

Tem uma tabela que relaciona os produtos de uma determinada compra, onde preciso consultar diversos produtos e retornar os ids das compras que tenham todos os produtos que consultei, em uma estrutura parecida com o exemplo abaixo:

 

SELECT  * FROM  produtos_has_compras WHERE (idProduto = 6 AND idProduto = 77 AND idProduto = 11) GROUP BY idCompra;

 

Alguém teria uma solução que possa me ajudar?

Share this post


Link to post
Share on other sites

Segue exemplo:

 

SQLs a SER UTILIZADAS

CREATE TABLE produtos (
	idProduto INT NOT NULL AUTO_INCREMENT,
	nomeProduto VARCHAR(50) NOT NULL,
	PRIMARY KEY(idProduto)
);
INSERT INTO produtos (nomeProduto) VALUES
('Suco de Laranja'),
('Fita Branca'),
('Linha Branca'),
('Creme');

CREATE TABLE compras (
	idCompra INT NOT NULL AUTO_INCREMENT,
	dataCompra DATE NOT NULL,
	PRIMARY KEY(idCompra)
);
INSERT INTO compras (dataCompra) VALUES
(CURRENT_DATE),
(CURRENT_DATE);

CREATE TABLE produtos_has_compras (
	idItem INT NOT NULL AUTO_INCREMENT,
	idCompra INT NOT NULL,
	idProduto INT NOT NULL,
	quantidade INT(5) NOT NULL,
	PRIMARY KEY(idItem),
	FOREIGN KEY(idCompra) REFERENCES compras (idCompra),
	FOREIGN KEY(idProduto) REFERENCES produtos (idProduto)
);
INSERT INTO produtos_has_compras (idCompra, idProduto, quantidade) VALUES
(1, 1, 10),
(1, 3, 1),
(1, 2, 1),
(2, 4, 2),
(2, 1, 1);

 

QUERY

SELECT
	idCompra
FROM
	produtos_has_compras
WHERE
	idProduto IN (1, 2, 3)
GROUP BY
	idCompra
;

 

Share this post


Link to post
Share on other sites

Obrigado meu caro, ms com IN não funciona porque irá trazer compras (ids) que podem ter comprado apenas um produto e não todos. Esse é o grande problema, preciso que retorne as compras que tenham todos os produtos. 

5 minutos atrás, ShadowDLL disse:

Segue exemplo:

 

SQLs a SER UTILIZADAS


CREATE TABLE produtos (
	idProduto INT NOT NULL AUTO_INCREMENT,
	nomeProduto VARCHAR(50) NOT NULL,
	PRIMARY KEY(idProduto)
);
INSERT INTO produtos (nomeProduto) VALUES
('Suco de Laranja'),
('Fita Branca'),
('Linha Branca'),
('Creme');

CREATE TABLE compras (
	idCompra INT NOT NULL AUTO_INCREMENT,
	dataCompra DATE NOT NULL,
	PRIMARY KEY(idCompra)
);
INSERT INTO compras (dataCompra) VALUES
(CURRENT_DATE),
(CURRENT_DATE);

CREATE TABLE produtos_has_compras (
	idItem INT NOT NULL AUTO_INCREMENT,
	idCompra INT NOT NULL,
	idProduto INT NOT NULL,
	quantidade INT(5) NOT NULL,
	PRIMARY KEY(idItem),
	FOREIGN KEY(idCompra) REFERENCES compras (idCompra),
	FOREIGN KEY(idProduto) REFERENCES produtos (idProduto)
);
INSERT INTO produtos_has_compras (idCompra, idProduto, quantidade) VALUES
(1, 1, 10),
(1, 3, 1),
(1, 2, 1),
(2, 4, 2),
(2, 1, 1);

 

QUERY


SELECT
	idCompra
FROM
	produtos_has_compras
WHERE
	idProduto IN (1, 2, 3)
GROUP BY
	idCompra
;

 

 

6 minutos atrás, ShadowDLL disse:

Segue exemplo:

 

SQLs a SER UTILIZADAS


CREATE TABLE produtos (
	idProduto INT NOT NULL AUTO_INCREMENT,
	nomeProduto VARCHAR(50) NOT NULL,
	PRIMARY KEY(idProduto)
);
INSERT INTO produtos (nomeProduto) VALUES
('Suco de Laranja'),
('Fita Branca'),
('Linha Branca'),
('Creme');

CREATE TABLE compras (
	idCompra INT NOT NULL AUTO_INCREMENT,
	dataCompra DATE NOT NULL,
	PRIMARY KEY(idCompra)
);
INSERT INTO compras (dataCompra) VALUES
(CURRENT_DATE),
(CURRENT_DATE);

CREATE TABLE produtos_has_compras (
	idItem INT NOT NULL AUTO_INCREMENT,
	idCompra INT NOT NULL,
	idProduto INT NOT NULL,
	quantidade INT(5) NOT NULL,
	PRIMARY KEY(idItem),
	FOREIGN KEY(idCompra) REFERENCES compras (idCompra),
	FOREIGN KEY(idProduto) REFERENCES produtos (idProduto)
);
INSERT INTO produtos_has_compras (idCompra, idProduto, quantidade) VALUES
(1, 1, 10),
(1, 3, 1),
(1, 2, 1),
(2, 4, 2),
(2, 1, 1);

 

QUERY


SELECT
	idCompra
FROM
	produtos_has_compras
WHERE
	idProduto IN (1, 2, 3)
GROUP BY
	idCompra
;

 

Obrigado meu caro, mas com IN não funciona porque irá trazer compras (ids) que podem ter comprado apenas um produto e não todos. Esse é o grande problema, preciso que retorne as compras que tenham todos os produtos. 

Share this post


Link to post
Share on other sites
as compras que tenham todos os produtos

 

Da sql acima

 

SELECT
	idCompra
FROM
	produtos_has_compras
WHERE
	idProduto IN (1, 2, 3)
GROUP BY
	idCompra
HAVING Count(distinct idProduto) = 3    
;

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Rebeca Julia Bronzatti
      Como salvar um formulário que possui duas tabelas, tenho uma tabela imóvel e outra arquivoimagem, gostaria de saber como salvar as duas, vi algumas coisas como dar um insert de cada vez no entanto eu não consigo recuperar a imagem, ele nem entra no if pra salvar a imagem. Se alguém puder me ajudar agradeço e muito to batendo a cabeça faz um tempo e não consigo resolver o bo.
       
      <?php include 'Conexao.php'; $nome = $_POST['nome']; $idade = $_POST['idade']; $sexo = $_POST['sexo']; $arquivo = isset($_FILES['arquivo']) ? $_FILES['arquivo'] : ""; $sql = "INSERT INTO usuario(nome, idade, sexo) VALUES ('$nome', '$idade', '$sexo')"; $resultado = mysqli_query($cnn, $sql); if(!$sql){ echo 'não salvou'; }else{ echo 'salvou'; } if (isset($_FILES['arquivo'])) { $nome = $arquivo['name']; $tiposPermitidos = ['jpg', 'jpeg', 'png']; $quantArquivos = count($_FILES['arquivo']['name']); $contador = 0; while ($contador < $quantArquivos) { $extensao = pathinfo($_FILES['arquivo']['name'][$contador], PATHINFO_EXTENSION); $temporario = $_FILES['arquivo']['tmp_name'][$contador]; if (in_array($extensao, $tiposPermitidos)) { $tamanho = $arquivo ['size']; $novo_nome = uniqid().".$extensao" ; $diretorio = "upload/"; if(move_uploaded_file($temporario, $diretorio . $novo_nome)){ echo "Upload feito com sucesso $novo_nome<br>"; $sql_code = "INSERT INTO arquivoimagem (arquivo, data) VALUE ('$novo_nome', NOW())"; header("Location: MostraImagem.php"); if (mysqli_query($cnn, $sql_code)) { $msg = "Arquivo enviado com sucesso!"; } else { $msg = "Falha ao enviar arquivo"; } } } else { print "Tipo de arquivo não permitido"; } $contador++; } }
          
       
    • By rogerblower
      o Google me avisou de dois erros no meu site;
       
      Clickable elements too close together
      Text too small to read
       
      Na verificação constatei que o erro é;
       
      Fatal error:  Call to undefined function db_connect() in
       
      O php não me mostra esse erro mesmo habilitando os erros no php ini os arquivos de conexão que estou usando são;
       
      ini.php
      <?php define('DB_HOST', 'localhost'); define('DB_USER', 'user'); define('DB_PASS', 'senha'); define('DB_NAME', 'banco'); ini_set('display_errors', true); error_reporting(E_ALL); require_once 'functions.php'; functions.php
       
      <?php function db_connect() { $pdo = new PDO('mysql:host=' . DB_HOST . ';dbname=' . DB_NAME . ';charset=utf8', DB_USER, DB_PASS); return $pdo; } function make_hash($str) { return sha1(md5($str)); } function isLoggedIn() { if (!isset($_SESSION['logged_in']) || $_SESSION['logged_in']!== true) { return false; } return true; } O erro esta nesta linha
      <?php $pdo = db_connect(); $sql = $pdo->prepare("SELECT * FROM servicos "); $sql->execute(); while($row=$sql->fetch(PDO::FETCH_ASSOC)){ echo'<a href="servicos.php?id='.$row['id'].'">'.$row['servico'].'</a>'; } Incluo a conexão com banco na header.php e nas demais páginas não aparece o erro
      realmente não sei o que pode estar acontecendo.
      se alguém pode me ajudar?
       
      Obrigado
       
    • By Rafaelax
      Oi queridos,
      Não sou programadora e nem entusiasta de programação, apenas altero algumas coisas no meu programa que tenho de cadastro de clientes. Coisas básicas vamos dizer;
      Para facilitar tudo, quando o programa foi criado, foi feito um campo de data automático no banco de dados como abaixo.
      `date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
       
      Funciona bem para o que preciso, mas ele traz a data nesse formato: 2020-03-25 00:20:03
      Data no formato ano/mês/dia e eu queria no formato tradicional dia/mês/ano.
      Só para levar em conta. eu trago a data para visualizar em um campo normal de inpunt com o value="[date]"
      Esse acima é um dos problemas que quero resolver com a parte da data.
       
      Já a segunda questão é justamente envolvendo essa data automática, pois qualquer edição que faço ele atualiza a data e o horário. Perfeito. Mas perco a data de cadastro original do cliente. É possível eu ter um outro campo de data automático mas que apenas grave o cadastro e não  atualize automaticamente nas edições?
       
      Eu queria que uma data fosse do cadastro e não atualizasse e outra data continuasse como está, apenas fazendo a inversão.
      Não adianta eu colocar a data manual no cadastro, pois pessoas colocam datas diferentes das do dia do cadastro.
       
    • By FabianoSouza
      Quero fazer um select que me permita escolher em qual coluna a pesquisa deverá ocorrer.
      Na minha cabeça a coisa deveria ser com essa lógica:
       
      DECLARE 
      @strPesquisa varchar(60)
      , @colunaPesquisa varchar(60)
       
      SET @colunaPesquisa = 'nome'
      SET @strPesquisa = 'Al Pacino'
       
      SELECT * FROM minhaTabela WHERE
      @colunaPesquisa LIKE '%'+ @strPesquisa +'%'
       
      Claro que essa sintaxe não funciona. Mas a lógica seria essa.
       
      Com crio isso?
       
      Grato.
    • By juliosertori
      Opa tudo bem?
       
      Tenho uma query que agrupa por CIDADE, o problema é que o cliente pode digitar a cidade, então as vezes digita com e sem caracter especial, por exemplo: São Paulo, e Sao Paulo, como posso agrupar os 2?
       
      "SELECT sum(p.total_pedido) as totalpedidos, p.id_empresa, p.id_cliente, c.id, c.cidade FROM pedidos AS p JOIN clientes AS c ON p.id_cliente = c.id WHERE p.id_empresa = '".$_CPD['CompanyId']."' AND p.finalizado = '1' AND MONTH(p.data_pedido) = '$mes_atual' group by c.cidade order by totalpedidos desc limit 0,10"  
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.