Dúvida sobre dataReader mySQL c#

3 respostas
Z

Bom dia galera! Estou com uma dúvida aqui referente a utilização certa do dataReader e como fazer o proximo passo, nessa parte do meu código eu preciso clickar no botão editar que fica ao lado dos usuários cadastrados, ao clicar ele vai me redirecionar para página de cadastro para realizar a edição, porém eu preciso que quando isso ocorra, ele já puxe as informações do usuário.
Entre o conn.Open e conn.Close eu preciso realizar um comando pra puxar essas informações, pois já usei select pra ler, agora só falta isso mas não to sabendo como fazer! Se alguem conseguir me ajudar ficaria super grato.

Att Vinicius

protected void grid_SelectedIndexChanged(object sender, EventArgs e)

{

string _sql =  SELECT +

" USUA_CODIGO," +

" USUA_LOGIN," +

" USUA_NOME," +

" USUA_STATUS," +

" grupos.GRUP_CODIGO" +

" FROM" +

" usuarios" +

" INNER JOIN grupos ON grupos.GRUP_CODIGO = usuarios.GRUP_CODIGO" +

" ORDER BY" +

" GRUP_CODIGO DESC";
MySqlCommand cmd = new MySqlCommand(_sql, conn);

    try
    {
        conn.Open();
        MySqlDataReader reader = cmd.ExecuteReader();
        
            
        
        reader.close();
        MultiView1.ActiveViewIndex = 1;
    }
    

    catch (MySqlException ex)
    {
        MessageBox1.ShowMessage(ex.Message);
    }
finally
{
    conn.Close();

}

}

3 Respostas

J

Usa o método Read() do DataReader. Dá uma olhada nesses exemplos:

http://www.daveoncsharp.com/2009/11/retrieving-data-from-a-mysql-database/

Z

Fiz assim e consegui !
Valeu pela ajuda

protected void grid_SelectedIndexChanged(object sender, EventArgs e)
{

string _sql = "SELECT" +
   " USUA_CODIGO," +
   " USUA_LOGIN," +
   " USUA_NOME," +
   " USUA_STATUS," +
   " grupos.GRUP_CODIGO" +
   " FROM" +
   " usuarios" +
   " INNER JOIN grupos ON grupos.GRUP_CODIGO = usuarios.GRUP_CODIGO" +
   " ORDER BY" +
   " GRUP_CODIGO DESC";

    

    try
    {

  
        MySqlCommand cmd = new MySqlCommand(_sql, conn);
        MySqlDataReader reader = cmd.ExecuteReader();
        while (reader.Read())
        {
            conn.Open();
            
            txtLogin.Text = reader["USUA_LOGIN"].ToString();
            txtNome.Text = reader["USUA_NOME"].ToString();
            cboStatus.SelectedValue = reader["USUA_STATUS"].ToString();
            cboGrupos.SelectedValue = reader["GRUP_CODIGO"].ToString();
            
        }


        
        MultiView1.ActiveViewIndex = 1;
    }


    catch (MySqlException ex)
    {
        MessageBox1.ShowMessage(ex.Message);
    }
    finally
    {
        if (conn != null) conn.Close();

    }
  
}
J

Só retira esse conn.Open() de dentro do loop.

Criado 19 de setembro de 2018
Ultima resposta 19 de set. de 2018
Respostas 3
Participantes 2