Jump to content
mateus.andriollo

[RESOLVIDO] Função para legendas

Recommended Posts

Boa tarde,

Tenho alguns campos numéricos q ao fazer uma select gostaria q retornasse uma legenda

 

exemplo:

  • Status: 0=Inativo / 1=Ativo
  • Condição: 1=Funcionando / 2=Em manutenção / 3=Manutenção Interna 

 

Seria algo assim, tenho varias tabelas com estes campos... mas tenho q ficar usando replace.

Existe uma forma de criar uma função para isso? Nem q na função eu tenha que setar nome do campo, ficando assim:

  • Legenda('Status',cadastro.status) 

Share this post


Link to post
Share on other sites

Share this post


Link to post
Share on other sites

Agradeço pela atenção Motta,

Olhando não consegui assimilar, pensei em criar uma tabela auxiliar da seguinte forma

Tab: legenda

CREATE TABLE `homol`.`legenda` ( 
  `id` INT NOT NULL AUTO_INCREMENT ,
  `campo` VARCHAR(20) NOT NULL ,
  `valor` VARCHAR(10) NOT NULL ,
  `result` VARCHAR(30) NOT NULL,
  PRIMARY KEY (`id`),
  INDEX (`campo`)
)

ai pensei em criar uma função, estarei pesquisando mais sobre colunas virtuais, mas pelo que vi não sei se seria o que preciso.

Share this post


Link to post
Share on other sites

Não entendi o seu problema então , tente mostrar um exemplo.

Share this post


Link to post
Share on other sites

Estou ai falando o q penso...

select id, Legenda(status,1) as st, Legenda(sim,0) from tab

-- função legenda
função Legenda(campo, valor){

return select resp from legenda where campo like campo and valor like valor,

}

 

Em resumo, invés de usar replace eu busco em uma fun~ção Legenda que consulta em uma tabela consulta

 

Tabela legenda

 

Campo | Valor | Resp

Sim      | 1         | Sim

Sim      |0         |Não

Status| 1        | Ativo

Status|0         | Inativo

UF      |SP      | São Paulo

UF      |RJ     | Rio de Janeiro

 

Share this post


Link to post
Share on other sites

Seriam tabelas de contra domínio que seriam acessas por join.

 

Fora isto poderia ser usar Coluna Virtual ou usar um CASE.

 

Tabelas se usam em geral quando o domínio podem variar , por exemplo Forma de Pagamento (surgiu o PIX)

 

Não tendo alterações pode-se partir para CASE por exemplo.

 

A Coluna Virtual simplifica a geração dos SQLs

 

 

Share this post


Link to post
Share on other sites

Achei uma forma :tounge_wink:

Função para pesquisa da legenda

CREATE FUNCTION legenda(scampo VARCHAR(20), svalor  VARCHAR(10))
RETURNS VARCHAR(100)
DETERMINISTIC
BEGIN
  DECLARE resp VARCHAR(50);
  SET resp = 'N/A';
  SELECT result INTO resp
    FROM legenda
    WHERE LOWER(campo) like LOWER(scampo) and LOWER(valor) like LOWER(svalor);
  RETURN resp;
END

Tabela de legendas

CREATE TABLE `homol`.`legenda` ( 
  `id` INT NOT NULL AUTO_INCREMENT ,
  `campo` VARCHAR(20) NOT NULL ,
  `valor` VARCHAR(10) NOT NULL ,
  `result` VARCHAR(30) NOT NULL,
  PRIMARY KEY (`id`),
  INDEX (`campo`)
)

Tabela

image.png.09c06afd48a7db50874fa864e0a0fd9c.png

 

Query

SELECT STATUS, legenda('EquipaSt',status) as st2 FROM equipa WHERE 1

Resultado

image.png.500feab3a7746a5c7e5a0f939f9eed48.png

 

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 Luiz Henrique
      Olá pessoas,
       
      Tenho uma classe e dentro dela várias chamadas para métodos de acordo com a necessidade em outra classe (para obter dados DB), como são muitas e vou duplicar os arquivos, para ganhar tempo queria colocar o nome da classe em uma variável porém não funciona.
       
      use Class1; class Class2 { public $className = 'Class1'; ... $dados = $this->className::function(); // não funciona } Era para gerar isso:
      $dados = Class1::function();
      Se eu der um echo $this->$className, ele me retorno o nome da Class1 porém para executar um método dentro da Class1 não vai, diz que a classe Class1 não existe!
      Tem alguma forma de funcionar isso?
       
      Obrigado.
    • By joagostini
      Olá, sou iniciante, e estou fazendo, como exercício, o jogo da velha. 'Desenvolvi' uma rotina de escolha de nível do jogo (serão 3 níveis) que deve aguardar a escolha do usuário para o programa prosseguir. Mas acho que não entendi direito como o javascript funciona, pois o que fiz não funciona e não encontrei uma solução (talvez não saíba como pesquisar corretamente o assunto na web).

      O começo do HTML (que é pouco) onde está um select para escolha do nível é este:
      <body>     <div id="dvmenu">         <button onclick="iniciar()">Iniciar Jogo</button>         <p><br></p>         <div id="dvQuemComeca">             <label for="nivel">Escolha o nivel:</label>             <select id="nivel" onChange='atualiza()'>                 <option value=0 selected>Escolha um nível</option>                 <option value=1>Nível 1 - Brincadeira</option>                 <option value=2>Nivel 2 - Surpresa</option>                 <option value=3>Nível 3 - Desafio</option>             </select>         </div>         <div id="jogador" class="jogador"></div>         <div id="vencedor" class="jogador"></div>     </div>  
      O código JS é este:
      //INÍCIO VEM DE LOAD function iniciar() {     casela = document.querySelectorAll('div[id^="p"]');     for (let cas of casela) {         cas.innerHTML = '';     }     for (let i = 0; i < 9; i++){        tab = tab;     }     console.log(tab);     nivel = 0;      msg = '';     qtosLancesJog = 0;     sorteiaJogador();     //até aqui funcionou direito } //-------------------------------------------------------------------- //ESCOLHA DO NÍVEL DO JOGO function atualiza(){     let selecao = document.querySelector('#nivel');     let opcao = selecao.options[selecao.selectedIndex];     return opcao.value;    }   //--------------------------------------------------------------------   //SORTEIA QUEM VAI COMEÇAR JOGANDO //função para definir o jogador que inicia o tab function sorteiaJogador() {//funcionou direito     let quemComeca = parseInt(Math.floor(Math.random() * 2));     if (quemComeca == 0) {         msg = 'Computador';         //setTimeout(lanceCpu, 2000);//dá um intervalo antes do computador realizar o 1 lance         lanceCpu();     } else msg = 'Humano';//neste caso a rotina espera que o jogador clique no tabuleiro, qdo roda a função lancetab(pos)         lanceHumano();     document.querySelector('#jogador').innerHTML = `<br>O ${msg} começa!`; } //--------------------------------------------------------------------   //ESCOLHA RANDÔMICA, NIVEL = 1, Da POSIÇÃO DO LANCE DA CPU NO tabULEIRO function jogouCpu(){//funcionou direito //nível 1 modo randômico pos = Math.floor(Math.random() * 9); return pos; }   //função humana function lanceHumano(){     console.log('Estou na função humana');     do {         nivel = atualiza();         console.log(nivel);     } while (nivel === 0);     console.log(nivel + ' passei direto'); }  
      O problema está nesse do...while da function lanceHumano(). Segundo entendi, ele prosseguiria apenas quando nivel!== 0, caso contrário, ficaria 'preso' até o momento que o usuário escolhesse uma das opções. Pelo HTML percebesse que setei o select para value=0. Mas ele nem se dá ao trabalho de esperar um miléssimo de segundo, segue em frente com o valor que tiver, no caso 0. O while  não tem efeito. Essa minha perspectiva está errada? Se sim, o que fazer? (paradigma funcional, await?) Obrigado.
      P.S.. No código tem uns conole.logs que servem watch-dogs para ajudar a entender por onde vão as rotinas.
       
       
       
       
       
       
       
       
       
       
       
       
       
       
       
       
       
       
       
    • By ernestovm
      Bom dia.
      Descobri, depois de muito trabalho, um problema esquisito. Tenho duas imagens que chamam funções JavaScript determinadas. Uma funciona e a outra não. Isso no Firefox. No Chrome as duas funcionam perfeitamente. Alguém conhece alguma gambiarra para fazer o Firefox funcionar? Segue os códigos:
      HTML:
      <img src="images/ic_abrir.png" width="70" height="70" onClick="abre_notificacao(<? echo "'".$us_codigo."','".$item."'"; ?>);" style="cursor:pointer" id="p_imagem-<? echo $item; ?>" name="p_imagem-<? echo $item; ?>">
       <img src="images/ic_excluir.png" width="70" height="70" onClick="excluir_notificacao(<? echo "'".$us_codigo."'"; ?>);" style="cursor:pointer">
      JAVASCRIPT:
      <script type="text/javascript">
          function abre_notificacao(codigo,indice) {
              $("#p_imagem-"+indice).attr("src","images/ic_abrir_ok.png");
              $("#ver-"+indice).css("display", "block");
          }
          function excluir_notificacao(codigo) {
              $.post("excluir_notificacao.php", {codigo: codigo}, function(resposta) {
                  confirm(resposta+" ("+codigo+")");
              });
              location.reload();
          }

      </script>
      A Função abre_notificacao(codigo,indice)  funciona perfeitamente nos dois browsers.
      A Função excluir_notificacao(codigo) só funciona no Chrome.
      Obrigado pela luz
    • By unset
      Olá, estou começando a usar o twig template e estou com uma dúvida e não encontrei a resposta também não sei se é possível mais espero que seja possível
       
      Bom eu tenho um arquivo com várias funções, como eu faço para chamar essas funções no HTML?
       
      Não funciona assim {{ funcao() }}
    • By Luiz Henrique
      Olá,
      Existe alguma forma de executar a função dentro da mesma?
      EX:
       
      function pai(){
          pai();
      }
       
      Obrigado.
×

Important Information

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