Em determinado momento nos deparamos com a seguinte situação, nossa tabela do banco de dados possui como campo chave, um ID por exemplo, incrementado por uma rotina da aplicação, do banco ou algum outro mecanismo de incremento (sequences, increment, etc), logo não há porque mostrar essa coluna para o usuário porque o mesmo não sabe de sua existência, e seu valor não tem qualquer relevância para ele, sendo assim o mais lógico a se fazer é não mostra-lá na aplicação.
Seu valor é necessário já que por se tratar de uma chave primária precisaremos dela para atualizar, inserir ou excluir os dados, então o que fazer?
A resposta seria simples, deixemos ele invisível, buscaremos seu valor e o usuário não perceberá, porém a partir da versão 2005 do visual Studio as colunas setadas com "visible = false" não são renderizadas, com isso ao se tentar acessar seu valor o que recebemos é nada.
Para contornarmos essa situação podemos codificar o seguinte:
Seu valor é necessário já que por se tratar de uma chave primária precisaremos dela para atualizar, inserir ou excluir os dados, então o que fazer?
A resposta seria simples, deixemos ele invisível, buscaremos seu valor e o usuário não perceberá, porém a partir da versão 2005 do visual Studio as colunas setadas com "visible = false" não são renderizadas, com isso ao se tentar acessar seu valor o que recebemos é nada.
Para contornarmos essa situação podemos codificar o seguinte:
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
#region "Deixa invisível a coluna"
switch (e.Row.RowType)
{
case DataControlRowType.Header:
e.Row.Cells[0].Visible = false;
break;
case DataControlRowType.DataRow:
e.Row.Cells[0].Visible = false;
break;
case DataControlRowType.Footer:
e.Row.Cells[0].Visible = false;
break;
}
#endregion
}
{
#region "Deixa invisível a coluna"
switch (e.Row.RowType)
{
case DataControlRowType.Header:
e.Row.Cells[0].Visible = false;
break;
case DataControlRowType.DataRow:
e.Row.Cells[0].Visible = false;
break;
case DataControlRowType.Footer:
e.Row.Cells[0].Visible = false;
break;
}
#endregion
}
Com isso nossa coluna não irá aparecer no GridView e conseguiremos acessar seu valor.
Hahaha! Foi até engraçado... entrei aqui no seu blog, assim, como quem não quer nada... e dei de cara com um texto desses, do qual não entendi bulhufas! =p
ResponderExcluirMas isso há de ser útil para alguém, certo?!
Bjo
Oi Daiazinha, realmente para alguns é útil, hehe, os posts técnicos tem sido os mais visitados, porém menos comentados. Eu também tenho artigos menos técnicos em "Diversos", dê uma olhada, talvez encontre algo interessante para você...
ResponderExcluirbjos e obrigado pela visita...
Parabens, solucionou meu problema em um CONTROL C + CONTROL V.
ResponderExcluirContinue assim amigo.
Fico muito mas muito feliz mesmo que o código tenha lhe ajudado Vitorlui, abraços e continue a nos visitar...
ResponderExcluirAlguém ja precisaram fazer isso no evento rowcommand?
ResponderExcluirOlá Everton, nunca testei, algum motivo em especial para ser nesse evento?
ResponderExcluirOlá Everton,
ResponderExcluirGostaria de saber qual comando utilizar para determinar se o gridview vai receber um valor do banco de dados ou não, e assim eu poder usar a condição: if gridview(recebe um valor do select sql) then... / else... end if
to quebrando a cabeça para saber se tem como utilizar esse comando, mas não to achando.
Marcia darei uma pesquisada, nunca precisei fazer nada do tipo, se eu encontrar algo eu respondo aqui...
ResponderExcluirOlá novamente Marcia, quem define a fonte de dados (DataSource) do GridView é o próprio programador, se você esta alternando entre um banco de dados e um arquivo talvez seja mais fácil verificar no momento em que isso ocorre, qualquer coisa nos de mais detalhes, bjos...
ResponderExcluirvaleu pela dica! =)
ResponderExcluirOlá Diogo, fico feliz em ter ajudado...
ResponderExcluirCARA....
ResponderExcluirVALEU!!!
Você programa comigo!! hehehe! Sempre copio e colo isso aqui e hoje decidí postar um comment!
Obrigado por existir!
hehehe
Não consigo fazer isso, meu vs 2008 reclama do seguinte:
ResponderExcluirO nome 'DataControlRowType' não existe no contexto atual
Sabe o que pode ser isso?
Vlw.. Abraços!
Opaa... ja resolvi sozinho, esqueci de importar o System.Web.UI.WebControls! uhahuauh
ResponderExcluirDei mole, mas já que ainda estou aqui... eu tenho uma coluna do tipo select na minha grid, e quero passar por exemplo o que ta escrito na coluna "nome" (o texto) para essa coluna Select, como eu faço? você sabe?
Em VB.net é mais ou menos assim:
CType(e.Row.Cells(4).Controls(0), LinkButton).Text = e.Row.Cells(2).Text;
Vlw de novo, abraços!
Meus amigos Pedro e Danilo, fico feliz que de alguma maneira eu tenha ajudado, abraços e obrigado pela visita !
ResponderExcluirCara, salvou minha madrugada. Com isso posso dormir mais cedo hoje.. hehehhe
ResponderExcluirAbraços Vlw mesmo
Valeu cara!
ResponderExcluirMuito boa dica.. salvou meu grid!
heheh
Bruxo! Valeu...
ResponderExcluirEu estava procurando exatamente isso...Continue assim..sempre terá alguém como eu (precisando de ajuda)
edertecmail@gmail.com
Muito bem Esse código...valeu mesmo...
ResponderExcluirDICA PERFEITA!!!!!!!
ResponderExcluirMuito obrigado.
Cristiano Fischer
Deutschland
Muito obrigada! Excelente dica, me ajudou pra caramba!
ResponderExcluirOlá Denise ! Que bom que ajudou.
ResponderExcluirMuito Obrigado amigo!!!
ResponderExcluirme salvou agora! rs
Valeuu!
Olá Diego fico feliz em ter ajudado.
ExcluirValeu Eduardo! Ajudo muito!
ResponderExcluirAbraços