Pular para o conteúdo principal

Como pegar valor de coluna invisível do GridView

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:
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
    }
Com isso nossa coluna não irá aparecer no GridView e conseguiremos acessar seu valor.

Comentários

  1. 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

    Mas isso há de ser útil para alguém, certo?!


    Bjo

    ResponderExcluir
  2. 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ê...
    bjos e obrigado pela visita...

    ResponderExcluir
  3. Parabens, solucionou meu problema em um CONTROL C + CONTROL V.

    Continue assim amigo.

    ResponderExcluir
  4. Fico muito mas muito feliz mesmo que o código tenha lhe ajudado Vitorlui, abraços e continue a nos visitar...

    ResponderExcluir
  5. Alguém ja precisaram fazer isso no evento rowcommand?

    ResponderExcluir
  6. Olá Everton, nunca testei, algum motivo em especial para ser nesse evento?

    ResponderExcluir
  7. Olá Everton,
    Gostaria 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.

    ResponderExcluir
  8. Marcia darei uma pesquisada, nunca precisei fazer nada do tipo, se eu encontrar algo eu respondo aqui...

    ResponderExcluir
  9. Olá 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...

    ResponderExcluir
  10. Olá Diogo, fico feliz em ter ajudado...

    ResponderExcluir
  11. CARA....
    VALEU!!!

    Você programa comigo!! hehehe! Sempre copio e colo isso aqui e hoje decidí postar um comment!

    Obrigado por existir!

    hehehe

    ResponderExcluir
  12. Não consigo fazer isso, meu vs 2008 reclama do seguinte:
    O nome 'DataControlRowType' não existe no contexto atual

    Sabe o que pode ser isso?
    Vlw.. Abraços!

    ResponderExcluir
  13. Opaa... ja resolvi sozinho, esqueci de importar o System.Web.UI.WebControls! uhahuauh

    Dei 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!

    ResponderExcluir
  14. Meus amigos Pedro e Danilo, fico feliz que de alguma maneira eu tenha ajudado, abraços e obrigado pela visita !

    ResponderExcluir
  15. Cara, salvou minha madrugada. Com isso posso dormir mais cedo hoje.. hehehhe
    Abraços Vlw mesmo

    ResponderExcluir
  16. Valeu cara!

    Muito boa dica.. salvou meu grid!

    heheh

    ResponderExcluir
  17. Bruxo! Valeu...
    Eu estava procurando exatamente isso...Continue assim..sempre terá alguém como eu (precisando de ajuda)

    edertecmail@gmail.com

    ResponderExcluir
  18. Muito bem Esse código...valeu mesmo...

    ResponderExcluir
  19. DICA PERFEITA!!!!!!!
    Muito obrigado.
    Cristiano Fischer
    Deutschland

    ResponderExcluir
  20. Muito obrigada! Excelente dica, me ajudou pra caramba!

    ResponderExcluir
  21. Muito Obrigado amigo!!!

    me salvou agora! rs

    Valeuu!

    ResponderExcluir
  22. Valeu Eduardo! Ajudo muito!

    Abraços

    ResponderExcluir

Postar um comentário

Obrigado por Participar do programero, fique a vontade para agradecer, retificar, perguntar ou sugerir.

Postagens mais visitadas deste blog

Iniciar e Parar Serviços do Windows (Delphi)

Em certas ocasiões nos deparamos com a necessidade de manipular determinadas atividades do SO, como iniciar ou parar um banco de dados, ou qualquer outro serviço que esteja funcionando no momento. Segue abaixo um código que encontrei na Internet para tal finalidade (não me recordo à fonte, assim que eu a encontrar colocarei).
Iniciar Serviço:

uses WinSvc;
//
// start service
//
// return TRUE if successful
//
// sMachine:
//   machine name, ie: \SERVER
//   empty = local machine
//
// sService
//   service name, ie: Alerter
//
function ServiceStart(
  sMachine,
  sService : string ) : boolean;
var
//
  // service control
  // manager handle
  schm,
//
  // service handle
  schs   : SC_Handle;
//
  // service status
  ss     : TServiceStatus;
//
  // temp char pointer
  psTemp : PChar;
//
  // check point
  dwChkP : DWord;
begin
  ss.dwCurrentState := -1;
// connect to the service
  // contr…

Alterar cores do PageControl (Delphi)

O padrão Windows todo cinza não é muito atraente, por isso quando nos utilizarmos do PageControl podemos alterar suas cores e fontes da seguinte maneira:
Em primeiro lugar devemos alterar a propriedade OwnerDraw para TRUE;
Depois implementar seu método DrawTab da seguinte maneira: //pinta a fonte
Control.Canvas.Font.Color:=clBlack;
//
// pinta a paleta / aba
Control.Canvas.brush.Color:=clSkyBlue;

PageControl1.Canvas.Rectangle(Rect);
Control.Canvas.TextOut(Rect.left+5,Rect.top+3,PageControl1.Pages[tabindex].Caption);
// pinta a parte interna (tabsheet)
PageControl1.Pages[TabIndex].brush.Color := Control.Canvas.brush.Color;
PageControl1.Pages[TabIndex].Repaint;

Caso a intenção seja manter cada aba com seu próprio estilo basta adicionar um CASE filtrando o índice das abas: case TabIndex of
  0: Control.Canvas.Font.Color:=clBlack;
  1: Control.Canvas.Font.Color:=clWindow;
  2: Control.Canvas.Font.Color:=clRed;
en…

Listar arquivos existentes em diretório (Delphi)

Mostraremos uma maneira simples e prática para listar o conteúdo de um diretório com a opção de incluir nessa listagem os arquivos de seus subdiretórios. No exemplo abaixo temos um Edit para receber o diretório a ser pesquisado um CheckBox para indicar se os subdiretórios entrarão na pesquisa um botão para efetuar a pesquisa e um Memo para listar os arquivos encontrados, no final um Edit que receberá o cálculo final (em bytes) da soma do tamanho dos arquivos. procedure TForm1.Button1Click(Sender: TObject);
begin
  tamanhoTotal := 0;
  memLista.Lines.Clear;
  ListarArquivos(edtDiretorio.Text, chkSub.Checked);
  Edit1.Text := IntToStr( tamanhoTotal );
end;
procedure TForm1.ListarArquivos(Diretorio: string; Sub:Boolean);
var
  F: TSearchRec;
  Ret: Integer;
  TempNome: string;
begin
  Ret := FindFirst(Diretorio+'\*.*', faAnyFile, F);
try
while Ret = 0 do
begin
if TemAtributo(F.Attr, faDirectory) then
begin
if (F.Name <> '.') And (F.Name &l…