Ir para conteúdo
PapaiJonh

Restringir lista com mais de uma condição para o mesmo campo

Recommended Posts

Ola, pessoal.

Estou trabalhando com Web Form e usando SQL como banco de dados.

Eu tenho um data grid com todos os Professores do meu banco e preciso atualizar essa lista de acordo com as condições.

a duvida é a seguinte, fiz um CheckBoxList com algumas matérias e estou na duvida de como fazer o select passando por exemplo 3 matérias.

//Esse é o método que chama o Buscar passando os parâmetros.

protected void DdProfessores_SelectedIndexChanged(object sender, EventArgs e)
        {
            Professor p = new Professor();
            dgProfessores.DataSource = p.Buscar_Selecionado(DdProfessores.SelectedValue, RbSexo.SelectedValue, ChbMaterias.SelectedValue);
            dgProfessores.DataBind();
            


        }



//Esse é o método do buscar

public DataSet Buscar_Selecionado(String n, String s, String m)//Funciona
        {
            DataSet ds = new DataSet();
            SqlConnection com = new SqlConnection("Data Source=JOHN-PC;Initial Catalog=FACEAR;Integrated Security=True");//conexão com o banco
            com.Open();
            string comando_sql = "select * from PROFESSOR where Id = @Id  and Sexo = @Sexo and Materia = @Materia";//string do comando SQL a ser utilizado
            SqlCommand comando = new SqlCommand(comando_sql, com);// intanciando um SqlCommando com a QUERY e a coneção
            SqlDataAdapter da = new SqlDataAdapter(comando); //
            comando.Parameters.Add("@Id", SqlDbType.Int);
            comando.Parameters["@Id"].Value = n;
            comando.Parameters.Add("@Sexo", SqlDbType.VarChar);
            comando.Parameters["@Sexo"].Value = s;
            comando.Parameters.Add("@Materia", SqlDbType.VarChar);
            comando.Parameters["@Materia"].Value = m;
            SqlDataReader dr = comando.ExecuteReader();
            dr.Close();
            da.Fill(ds);
            return ds;
        }

 

Editado por Gabriel Heming
adicionar marcação de código

Compartilhar este post


Link para o post
Compartilhar em outros sites

Acredito que você possa substituir sua query:

select * from PROFESSOR where Id = @Id  and Sexo = @Sexo and Materia = @Materia

Por algo como:
 

select * from PROFESSOR where Id = @Id  and Sexo = @Sexo and Materia in (@Materia1, @Materia2, @Materia3)

Claro terá que ter os códigos das matérias separados, pode usar um array ou uma lista.

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 eduardohaag
      Boa noite pessoal,
      Esbarrei em um novo problema com consultas no meu sistema.
       
      Tenho um formulário no sistema que deverá apresentar todos os materiais utilizados em uma determinada Venda e seus respectivos estoques obtidos através da soma das entradas e saidas do estoque.
      Para isso devo buscar os dados em 3 tabelas do banco de dados sendo elas VendasProdutos, Composicao,  Materiais e Estoque

       
      Eis que surge meu problema, como posso ter vários produtos na venda e alguns produtos usam os mesmos materiais, a consulta está retornando com os materiais duplicados, quando o que eu gostaria era que somasse de acordo com cada material.
       
      A query que estou usando para teste no acesso é a seguinte:
      SELECT Composicao.IdMaterial, materiais.descricao, Sum(Estoque.Quantidade) AS Estoque, [VendasProdutos]![Quantidade]*[Composicao]![Quantidade] AS TotalUtilizado FROM (VendasProdutos LEFT JOIN (materiais RIGHT JOIN Composicao ON materiais.ID = Composicao.IdMaterial) ON VendasProdutos.IdProduto = Composicao.IdProduto) LEFT JOIN Estoque ON materiais.ID = Estoque.IdMaterial GROUP BY Composicao.IdMaterial, materiais.descricao, [VendasProdutos]![Quantidade]*[Composicao]![Quantidade], VendasProdutos.IdVenda HAVING (((VendasProdutos.IdVenda)=1));  
      A consulta está retornando os dados dessa forma:

       
      E eu gostaria de que agrupasse por ex:
       
      ID                Descricao                Estoque               TotalUtilizado
      1                 Capa Agenda             34                             10
      2                 Miolo Agenda            27                              5
       
      Alguem Sabe como posso fazer isso?
      Desulpem pelo post gigante, mas não sabia como explicar melhor.
    • Por felipotrindade
      Galera boa noite! Preciso de uma ajuda de vocês com relação a um comando SQL no MySQL e depois no PHP.
      Tenho as seguintes tabelas e as suas colunas:
      Pessoa
       ID
       Nome
       
      Tratamento
       ID
       DESCRICAO
       
      ROTINAS
       ID
       ID_PESSOA
       ID_TRATAMENTO
       
      Por exemplo, quando eu insiro os registros nessas tabelas, onde, a rotina manterá o relacionamento entre pessoa e tratamento conforme abaixo:
      ROTINAS
      ID = 1 ID_PESSOA = 1 ID_TRATAMENTO = 1
      ID = 2 ID_PESSOA = 1 ID_TRATAMENTO = 2
       
      Supondo que, a pessoa se chame JOÃO, ou seja, ele aparece duas vezes na tabela rotinas conforme acima e, o tratamento 1 seja medição do nível de ph e o tratamento 2 seja temperatura da água. Usando o inner join fica assim:
      PESSOA TRATAMENTO.DESCRICAO
      JOÃO      MEDIÇÃO PH
      JOÃO      TEMPERATURA
       
      mysql> select pessoa.nome, tratamento.descricao from rotinas inner join pessoa on rotinas.id_pessoa=pessoa.id inner join tratamento on rotinas.id_tratamento=tratamento.id;
       
      Até ai tudo bem!!! Porém, ao invés de mostrar o comando select com os resultados linhas por linha, gostaria de agrupar pelo nome da pessoa e mostrar os tratamentos, no caso a descrição e colunas e não linha a linha repetindo o nome da pessoa várias vezes.
       
      Não sei se deu para entender! Peço desculpas por tentar explicar dessa forma rs.....
       
      Obrigado se puderem me ajudar!!!
    • Por Félix Henrique
      Boa noite nobres amigos.

      Estou com um problema em meu sisteminha, e não estou sabendo como resolver.

      Segue o link do sistema em funcionamento:
       
      http://locarweb.com.br/cotacao/

      O que eu queria?
      Que ao selecionar um tipo de sementes no 1º select, ele me desse as variedades de sementes disponíveis para esse tipo no 2º select.
      Seria estilo aqueles scripts de Estado/Cidade.

      Mas o que acontece?

      O problema maior ocorre quando vou duplicar a linha de pedidos, duplicando os selects acima.

      O erro acontece que você seleciona um tipo, mas fica disponível todas as variedades no próximo select.

      Seria tipo:
      TIPO ------------- > VARIEDADE
      Brachiara ------ > Decumbens
      Brachiara ------ > Brizantha

      Panicum ------ > Tanzânia
       
       
      Alguém poderia me ajudar a entender como faço para resolver esse problema?
       
    • Por Wictor Pamplona
      Olá, me chamo Wictor Pamplona e estou enfrentando um pequeno problema com HTML. Gostaria de pedir à ajuda de vocês para resolver essa questão.
       
      Veja, eu tenho um formulário aonde possuí vários SELECT, eu já produzi um código jQuery que faz a tradução deste select para HTML e altera o select ele estando oculto para o usuário, isto já está funcional. Porém, recentemente me surgiu a necessidade de inserir código HTML nestes options, tanto para ser imprimido como texto, como ser lido como html dentro da página.
      Sei que a dúvida parecer ser de javascript, porém não é (creio que possa ser resolvido com HTML).
       
      Vejamos, eu colocando o option assim:

      <option value=""><b>1-</b> Linha 1
      Eu queria que fosse traduzido para o select exatamente como foi escrito, sendo uma variável de texto não aplicando a estilização HTML: <b>1- Linha 1</b>.
      Porém, ainda assim apresenta só o texto sem o html, retornando no select apenas: 1- LInha 1, não imprimindo o html em texto.
    • Por cauai
      Olá,
      Eu estou tentando criar uma lista de vendedores que irão receber o contato de clientes através do meu site. É uma plataforma wordpress, porém tenho completo acesso ao código php.
      Até agora, só achei maneiras de enviar para múltiplos e-mails, como cópia, ou separando por departamento à escolha do cliente, utilizando o Contact Form 7, o que não é meu desejo.
      Quero algo como isso:
       
      Não sei se o Contact Form 7 me permitiria algo desse tipo, ou se teria mesmo que fazer pelo php. Mas aceito ajuda para ambos os casos.
×

Informação importante

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