Jump to content
ndias

array no select?

Recommended Posts

alguém conhece um jeito de no select percorrer valores separados por vírgula em um campo?

 

por ex: tenho um campo em uma tabela com os valores SB, BA

 

qro selecionar todos que contenham S e A

 

se eu usar o in ('S','A'), o resultado vai ser

S

A

 

ou seja, só vai trazer o valor que conter só S ou só A

 

e se eu usar o like '%S%' or like ''%A%, o resultado pode também ser

SB

BA

 

quero que traga, por exemplo:

S

SB

BA

A

 

Ou seja, se tiver o S e também outros valores no campo junto com o S

Share this post


Link to post
Share on other sites

Olá

 

Fiz algo parecido, só que com PHP e Javascript;

 

Vê se serve para você alguma coisa:

 

 

Segue código em Javascript

document.getElementById("btn-addCell").addEventListener('click', function() {
			
			
			
		/* Produto da Tabela */
		var selectProduto = document.createElement('select');
		selectProduto.className = 'updateFields select';
		selectProduto.setAttribute('name', 'nomeProduto[]');
			
			
		var tdSelectionOptionProduto = document.createElement('td');
		tdSelectionOptionProduto.appendChild(selectProduto);
 
  		/* Para colocar o Select no Body, dentro de uma tr (table) */
  		var tr = document.createElement('tr');
		tr.appendChild(tdSelectionOptionProduto);
  		document.getElementById("body-table").appendChild(tr);
		updateFields();
  
  
  		/* Para pegar os dados do MySQL/Array no seu caso */
  		var dados = [<?
			
			$i = 1;
			$sql7 = "SELECT * FROM produto ORDER BY nomeProduto ASC";
			$qr7 = mysqli_query($con, $sql7) or die(mysqli_error());
			$number = mysqli_num_rows($qr);
			while($ln7 = mysqli_fetch_assoc($qr7)){
				
			if($i < $number){
				echo '"'.$ln7['nomeProduto'].'", ';
			} else{
				echo '"'.$ln7['nomeProduto'].'"';
			}
				
				$i++;
			}
			?>];
			
		dados.forEach(function(item){
			$('.select').append('<option>' + item + '</option>');
			});
	});	
  		
  	
}

 

Vê se consegue implementar, qualquer coisa é só falar

Share this post


Link to post
Share on other sites

Se você usar o LIKE '%A%' OR LIKE '%S%' certamente irá listar S, SB, BA e A, pois todos estes registros contém 'A' ou 'S'.

 

Agora vem a dúvida: você afirmou que na tabela possui os valores 'SB' e 'BA'. Como quer que seja listado 'S' e 'A' se não contém na sua tabela? E caso você esteja considerando a possibilidade de haver também os valores 'S' e 'A', então os quatro resultados serão retornados na sua pesquisa no exemplo acima.

Share this post


Link to post
Share on other sites

Anthony, obrigado! Eu consigo resolver com dois arrays no PHP, mas quero uma solução no SQL para ganhar performance.

 

Eziquiel, esse foi só um exemplo que usei. Na tabela contém: só S, só A, só SB, só BA, S e A, S e SB, S e BA, SB e A...etc, etc, etc....

 

Enfim...todas as combinações possíveis...pode existir tudo  S, SB, BA e A

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 johnklo
      COM BASE NA TABELA HR DO ORACLE
      Preciso criar uma sub-rotina (procedure) que imprima na tela o número de funcionários (employees) agrupados por departamentos (department_id). Deve-se ordenar a saída em ordem decrescente pela quantidade de departamentos. Pode-se utilizar qualquer forma de cursor para imprimir o resultado.
    • By c3s1nha
      Boa tarde,
       
      Preciso restaurar a estrutura de um banco de dados (tabelas,views,procedures.. etc) em outro banco de dados que esta vazio (nao tem tabela nenhuma, banco novo), utilizo o sql server. Consigo fazer utilizando o SSMS ?
       
      Para entender melhor estou enviando uma imagem.
       
       
      O banco com todas tabelas,viwes,procedures, registros, etc..  é o Guara_ que esta no servidor   .\SQLEXPRESS   quero fazer uma copia identica dele no banco Nutri no servidor sdb.hsi.
       
      Desde ja agradeço. 

    • By Samuel Pietro
      Tenho um select em PDO e preciso que a consulta retornada vire uma variavel, mas a variavel só pega a ultima linha da tabela e eu preciso que pegue todas as linhas que existirem.
       
      $conexao = conexao::getInstance(); $sql = 'SELECT * FROM RegistroE'; $stm = $conexao->prepare($sql); $stm->execute(); $Sql = $stm->fetchAll(PDO::FETCH_OBJ); foreach ($Sql as $SqlReg): $conteudo_meio = picture_X($SqlReg->E_01,1) .picture_X($SqlReg->E_02,25) .picture_9($SqlReg->E_03,4) .picture_X($SqlReg->E_04,14) .picture_9($SqlReg->E_05,8) .picture_9($SqlReg->E_06,8) .picture_9($SqlReg->E_07,8) .picture_9($SqlReg->E_08,8) .picture_9($SqlReg->E_09,8) .complementoRegistro(96,"brancos") .picture_9($SqlReg->E_11,1) .complementoRegistro(1,"brancos") ; endforeach; Como eu poderia está fazendo isto?
    • By Anderson Campos da Silva
      Olá,
       
      Estou com um problema, que para alguns pode ser simples, é o seguinte:
       
      Tenho 2 tabela relacionadas, MODELO e EQUIPAMENTO
       
      TABELA MODELO
      idModelo (INT) - chave primária  
      txModelo (VARCHAR)
       
      TABELA EQUIPAMENTO 
      idEquipamento (INT) - chave primária   
      patrimonio (VARCHAR)
      situacao (VARCHAR)
      idModelo (INT) - Chave estrangeira
       
      O campo situação pode ser preenchido apenas apenas com PRODUÇÃO OU ESTOQUE.
       
      Enfim, preciso de um SELECT que retorne as seguintes colunas txModelo, quantidade de equipamentos por modelo, quantidade de equipamentos com PRODUÇÃO, e quantidade de equipamentos com ESTOQUE, exemplo:
       
      txModelo | total | produção | estoque
      CISCO           7            4                  3
      HP                15          10                 5
      DELL            10           2                   8
       
      Desde já agradeço
    • By alanbr00
      Olá,
       
      estou tendo dificuldade na instalação, nunca vi esse erro. Estou pensando seriamente em formatar.
       
      Esse é o log.
       
       


×

Important Information

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