Ir para conteúdo
ndias

select count case

Recommended Posts

preciso fazer um select assim:

 

Select count(CASE WHEN tbl1.dtCadastro = CURDATE() THEN '' ELSE NULL END) as qtdDia, tbl2.id
from tbl1
inner join tbl2 on tbl2.id = tbl1.id and tbl2.id = 123
where tbl1.int = 190273

 

eu quero que o Count me traga q a quantidade de registros no dia, e por por conta do tbl2.id = 123 ele está trazendo apenas um

 

alguém pode me ajudar, por favor?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Select sum(CASE WHEN tbl1 .dtCadastro = CURDATE() THEN 1 ELSE 0 END) as qtdDia, tbl2.id
from tbl1
inner join tbl2 on tbl2.id = tbl1.id and tbl2.id = 123
where tbl1.int = 190273

 

Mas deve ter uma forma melhor...

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Mota eu tenho esse select:

 

select e.IDEmpresa, e.Razao, e.Ramo, e.Cidade
from tblconexoes c inner join tblempresa e on e.IDEmpresa = c.idEmpresa 
where c.Excluido = 'N' and c.idCV = 190273

 

Preciso acrescentar isso sum(CASE WHEN tbl1 .dtCadastro = CURDATE() THEN 1 ELSE 0 END) as qtdDia

 

Quero que o resultado seja 

 

3579 LIFE  Comércio varejista  BELO HORIZONTE 3
3578 VIBE  Comércio de produtos  SAO PAULO 3
3577 NICE  Comércio de serviços  RIO DE JANEIRO 3

 

Depois preciso acrescentar e.IDEmpresa = 3578 na cláusula where e quero que o resultado seja assim:

 

3578 VIBE  Comércio de produtos  SAO PAULO 3

Compartilhar este post


Link para o post
Compartilhar em outros sites
Citar

Preciso acrescentar isso sum(CASE WHEN tbl1 .dtCadastro = CURDATE() THEN 1 ELSE 0 END) as qtdDia

 

select e.IDEmpresa, e.Razao, e.Ramo, e.Cidade,
sum(CASE WHEN tbl1 .dtCadastro = CURDATE() THEN 1 ELSE 0 END) as qtdDia
from tblconexoes c inner join tblempresa e on e.IDEmpresa = c.idEmpresa 
where c.Excluido = 'N' and c.idCV = 190273
group by .IDEmpresa, e.Razao, e.Ramo, e.Cidade
Citar


Depois preciso acrescentar e.IDEmpresa = 3578 na cláusula where e quero que o resultado seja assim:

 


 

select e.IDEmpresa, e.Razao, e.Ramo, e.Cidade,
sum(CASE WHEN tbl1 .dtCadastro = CURDATE() THEN 1 ELSE 0 END) as qtdDia
from tblconexoes c inner join tblempresa e on e.IDEmpresa = c.idEmpresa 
where c.Excluido = 'N' and c.idCV = 190273
and IDEmpresa = 3578 
group by .IDEmpresa, e.Razao, e.Ramo, e.Cidade

Creio ser apenas isto 


 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 27/07/2018 at 10:11, Motta disse:

 


select e.IDEmpresa, e.Razao, e.Ramo, e.Cidade,
sum(CASE WHEN tbl1 .dtCadastro = CURDATE() THEN 1 ELSE 0 END) as qtdDia
from tblconexoes c inner join tblempresa e on e.IDEmpresa = c.idEmpresa 
where c.Excluido = 'N' and c.idCV = 190273
group by .IDEmpresa, e.Razao, e.Ramo, e.Cidade


 


select e.IDEmpresa, e.Razao, e.Ramo, e.Cidade,
sum(CASE WHEN tbl1 .dtCadastro = CURDATE() THEN 1 ELSE 0 END) as qtdDia
from tblconexoes c inner join tblempresa e on e.IDEmpresa = c.idEmpresa 
where c.Excluido = 'N' and c.idCV = 190273
and IDEmpresa = 3578 
group by .IDEmpresa, e.Razao, e.Ramo, e.Cidade

Creio ser apenas isto 


 

muito obrigado @Mota É isso mesmo!!!

abraços

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

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por Victor Cometti
      Boa noite,
       
      Em algumas de minhas queries de insert eu atualizo quando encontro registro duplicado.
      insert into .... ON DUPLICATE KEY UPDATE ...... Só que descobrir que além de verificar a PRIMARY KEY ele verifica também campos UNIQUE (um ou outro).
      O interessante para mim seria que fizesse update só quando achasse a PRIMARY KEY duplicada e não o campo UNIQUE.
      É possível sem procedure? 
       
    • Por dungol
      Ola Pessoal,
      Comprei um script em php e Mysql e estou precisando de uma ajuda.
      É um script POS simples de vendas. Quando eu faço uma venda o recibo sai apenas o nome do cliente, o telefone e as informaçoes da compra, mas eu gostaria de adicionar neste recibo o endereço do cliente. Na tabela de compra já tem o campo endereço, mas eu não sei como fazer o script adicionar o endereço do cliente nessa  tabela. 
      Obrigada pela ajuda,
      Cristina
    • Por UPeralta
      Olá, preciso de ajuda. A minha função de fetch_object está acessando apenas a primeira linha do resultado da SELECT, mas a seleção está retornando duas linhas. Não sei o que eu estou fazendo errado.
      Class que está fazendo a consulta no banco de dados:
      <?php class permissao_grupo { //Variáveis referentes a colunas public $peg_codigo; public $peg_nome; //Variáveis padrão das classes public $con; public $sql; public $result; //Funções padrão para todas as classes public function __construct() { $this->con = new Conexao(); } public function fetch_object() { $this->result = $this->result->fetch_object(); foreach ($this->result AS $chave => $valor) { $this->$chave = $valor; } } public function num_rows() { return $this->result->num_rows; } //Funções da classe public function montaGrupoMenu() { $sql = "SELECT peg_codigo, peg_nome FROM permissao_grupo "; $this->result = $this->con->Executar($sql); return $this->result; } }  
      Class conexão
      <?php class Conexao { public $host = "localhost"; public $usuario = "root"; public $senha = ""; public $banco = "smart"; public $mysqli; public function __construct() { $this->Abrir(); } public function Abrir() { $this->mysqli = new mysqli(); $this->mysqli->connect($this->host, $this->usuario, $this->senha, $this->banco); } public function Fechar() { $mysqli->close(); } public function Executar($sql){ return $this->mysqli->query($sql); } public function fetch_object(){ print_r($this->mysqli->fetch_assoc()); } }  
      Alguém poderia me ajudar? Já tentei usar o fetch_assoc e o fetch_array para ver se funcionaria, mas também não deu certo.
    • Por Lucasw
      E aí pessoal, estou com um problema que me afrontou essa madrugada toda.
      Estou tentando duplicar valores de dentro de outro valor, porém na hora
      de duplicar eu não tenho conhecimento para um comando que crie novos IDS
      então, está dando erro a horas e eu em busca da solução.
      Podem me ajudar?
       
      INSERT INTO items_rooms (id, room_id, user_id)
      SELECT id, 15602, user_id
      FROM items_rooms WHERE room_id = '15601';
       
      (é onde está negrito que está o problema.)
       
      Bom dia a todos!
       
      CREATE TABLE `items_rooms` (
          `id` VARCHAR(23) NOT NULL,
          `user_id` INT(10) NOT NULL,
    • Por Marcones Borges
      Bom dia, esto tentando inserir dados de um formulário em duas tabelas ao mesmo tempo.
       
      Gostaria de sua ajuda!
       
      Arquivo Insere
       

      $conexao = conexao::getInstance();         // Recebe os dados enviados pela submissão         $acao  = (isset($_POST['acao'])) ? $_POST['acao'] : '';         $id    = (isset($_POST['id'])) ? $_POST['id'] : '';         $nome  = (isset($_POST['nome'])) ? $_POST['nome'] : '';         $funcao = (isset($_POST['funcao'])) ? $_POST['funcao'] : '';         $cpf   = (isset($_POST['cpf'])) ? str_replace(array('.','-'), '', $_POST['cpf']): '';         $status           = (isset($_POST['status'])) ? $_POST['status'] : '';   $sql = 'INSERT INTO historico (registro_ministro, descricao, data_registro, usuario )                VALUES(:registro_ministro, :descricao, :data_registro, :usuario )';                  $stm = $conexao->prepare($sql);             $stm->bindValue(':registro_ministro', $registro_ministro);             $stm->bindValue(':descricao', $descricao);             $stm->bindValue(':data_registro', $data_registro);             $stm->bindValue(':usuario', $usuario);             $retorno = $stm->execute();                          if ($retorno):                 echo "<div class='alert alert-success' role='alert'>Registro editado com sucesso, aguarde você está sendo redirecionado ...</div> ";             else:                 echo "<div class='alert alert-danger' role='alert'>Erro ao editar registro!</div> ";             endif;             echo "<meta http-equiv=refresh content='0;URL=ministros.php'>";         endif; $sql = 'INSERT INTO ministro (nome, cpf,  funcao, status )                VALUES(:nome, :cpf, :rg,  :funcao, :status, )';                                $stm = $conexao->prepare($sql);             $stm->bindValue(':nome', $nome);             $stm->bindValue(':cpf', $cpf);             $stm->bindValue(':status', $status);             $stm->bindValue(':funcao', $funcao);
       
      Porém só executa o ultimo código não executa o primeiro o que pode ser ?
       
×

Informação importante

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