Solved

GridView CheckBox OnCheckChanged Save To DataTable?

Posted on 2012-03-19
8
394 Views
Last Modified: 2012-03-20
I need to save ALL GridView CheckBoxes values to a dataset/datatable. This gets more interesting using a DataKey for col_ID. I have this much code:

foreach(GridViewRow gvr in GridView1.Rows)
{
      CheckBox cb = (CheckBox)gvr.FindControl("checkbox1");
      bool value = cb.Checked;
       

}
0
Comment
Question by:pointeman
  • 4
  • 4
8 Comments
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37737686
DataTable dt=new DataTable();
dt.Columns.Add(new DataColumn("Status",typeof(bool));
DataRow dr=null;
foreach(GridViewRow gvr in GridView1.Rows)
{
      CheckBox cb = (CheckBox)gvr.FindControl("checkbox1");
      if(cb!=null)
      {
      dr=dt.NewRow();
      bool value = cb.Checked;
      dr[0]=value;
      dt.Rows.Add(dr);
      }
}
dt.AcceptChanges();

Open in new window

0
 

Author Comment

by:pointeman
ID: 37740130
Need to add 2 items in the same row very simply. The Gridview datakey is col_ID.

row = "ID"  "Value"

The need a foreach to check the data. thx
0
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37740794
bind the id with gridviewrow using label then search for this label and add its value to another column in datatable..
DataTable dt=new DataTable();
dt.Columns.Add(new DataColumn("Status",typeof(bool));
dt.Columns.Add(new DataColumn("ID",typeof(string));
DataRow dr=null;
foreach(GridViewRow gvr in GridView1.Rows)
{
      CheckBox cb = (CheckBox)gvr.FindControl("checkbox1");
      Label lb = (Label)gvr.FindControl("lblId");
      if(cb!=null && lb!=null)
      {
      dr=dt.NewRow();
      bool value = cb.Checked;
      dr[0]=value;
      dr[1]=lb.Text;
      dt.Rows.Add(dr);
      }
}
dt.AcceptChanges();

Open in new window


Table Will Have:-
Status    ID
0
 

Author Comment

by:pointeman
ID: 37741891
Geting incorrect results like below, although the col_active is correct, the col_id should read 1-9

col_id= 9 col_active= True
col_id= 9 col_active= True
col_id= 9 col_active= True
col_id= 9 col_active = True
col_id= 9 col_active = True

[code so far]
 DataTable dt = new DataTable();
            dt.Columns.Add("col_id");
            dt.Columns.Add("col_active");
            DataRow dr = null;
            CheckBox cbSelectedHeader = (CheckBox)GridView1.HeaderRow.FindControl("ckbxheader");

            foreach (GridViewRow row in GridView1.Rows)
            {
                CheckBox ckbx = (CheckBox)row.FindControl("checkbox1");

                if (cbSelectedHeader.Checked == true)
                    ckbx.Checked = true;
                else
                    ckbx.Checked = false;

                dr = dt.NewRow();
                dr[0] = GridView1.DataKeys[row.RowIndex].Value.ToString();
                dr[1] = ckbx.Checked.ToString();
                dt.Rows.Add(dr);
            }
            dt.AcceptChanges();
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 20

Accepted Solution

by:
BuggyCoder earned 500 total points
ID: 37742102
Do This:-

for(int i=0;i<GridView1.Rows.Count;i++)
            {
                GridViewRow row = GridView1.Rows[i];
                CheckBox ckbx = (CheckBox)row.FindControl("checkbox1");

                if (cbSelectedHeader.Checked == true)
                    ckbx.Checked = true;
                else
                    ckbx.Checked = false;

                dr = dt.NewRow();
                dr[0] = GridView1.DataKeys[i].Value.ToString();
                dr[1] = ckbx.Checked.ToString();
                dt.Rows.Add(dr);
            }

Open in new window


Also read here:-
http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.gridview.datakeys.aspx
0
 

Author Comment

by:pointeman
ID: 37743853
The problem is with the datatable add row because the datakeys return nicely like so:

foreach (GridViewRow row in GridView1.Rows)
{
     System.Web.HttpContext.Current.Response.Write(GridView1.DataKeys[row.RowIndex]["col_id"].ToString() + "<br/>");
}
0
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37743949
glad you got the answer, please close the question....
0
 

Author Closing Comment

by:pointeman
ID: 37744486
thx a million
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
ASP.net VB.net Email  a webpage 3 30
Response.Redirect Open new Form/tab/page? 5 29
Adjust the position 3 45
IIS Authorization for Web Service 2 17
Just a quick little trick I learned recently.  Now that I'm using jQuery with abandon in my asp.net applications, I have grown tired of the following syntax:      (CODE) I suppose it just offends my sense of decency to put inline VBScript on a…
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
You have products, that come in variants and want to set different prices for them? Watch this micro tutorial that describes how to configure prices for Magento super attributes. Assigning simple products to configurable: We assigned simple products…
A company’s greatest vulnerability is their email. CEO fraud, ransomware and spear phishing attacks are the no1 threat to a company’s security. Cybercrime is responsible for the largest loss of money to companies today with losses projected to r…

948 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

23 Experts available now in Live!

Get 1:1 Help Now