设为首页
加入收藏
联系站长
您现在的位置: 网贝 >> 建站学院 >> ASP.NET >> winform应用 >> 文章正文 用户登录 新用户注册
[组图]联合主键的情况怎么在DataGrid中利用DataKeys定位记录?         ★★★
联合主键的情况怎么在DataGrid中利用DataKeys定位记录?
相关网站:
作者:lovecher… 文章来源:http://www.cnblogs.com/lovecherry 点击数: 更新时间:2005-6-21

比如表中三个字段
key1 int,key2 int,item varchar(50)
前面2个字段联合主键

前台代码:

<asp:DataGrid id="DataGrid1" runat="server" AutoGenerateColumns="False" DataKeyField="DoubleKey">
                
<Columns>
                    
<asp:BoundColumn DataField="item" HeaderText="item"></asp:BoundColumn>
                    
<asp:ButtonColumn CommandName="del" Text="删除"></asp:ButtonColumn>
                
</Columns>
            
</asp:DataGrid>


后台代码:

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;

namespace csdn2
{
    
public class WebForm20 : System.Web.UI.Page
    
{
        
protected System.Web.UI.WebControls.DataGrid DataGrid1;
    
        
private void Page_Load(object sender, System.EventArgs e)
        
{
            
if(!IsPostBack)
            
{
                SetBind();
            }

        }

        
private void SetBind()
        
{
            SqlConnection conn
=new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings["conn"]);
            SqlDataAdapter da
=new SqlDataAdapter("select * from doublekey",conn);
            DataSet ds
=new DataSet();
            da.Fill(ds);
            DataTable dt
=ds.Tables[0];
            DataColumn dc
=new DataColumn("DoubleKey",typeof(string),"key1+'#'+key2");
            dt.Columns.Add(dc);
            
this.DataGrid1.DataSource=dt;
            
this.DataGrid1.DataBind();
        }

        
Web 窗体设计器生成的代码

        
private void DataGrid1_ItemCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
        
{
            
if(e.CommandName=="del")
            
{
                SqlConnection conn
=new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings["conn"]); 
                SqlCommand comm
=new SqlCommand("delete from doublekey where key1=@key1 and key2=@key2",conn); 
                SqlParameter parm1
=new SqlParameter("@key1",SqlDbType.Int);
                SqlParameter parm2
=new SqlParameter("@key2",SqlDbType.Int); 
                
string [] keys=this.DataGrid1.DataKeys[e.Item.ItemIndex].ToString().Split('#');
                parm1.Value
=keys[0];
                parm2.Value
=keys[1];
                comm.Parameters.Add(parm1);
                comm.Parameters.Add(parm2); 
                conn.Open(); 
                comm.ExecuteNonQuery(); 
                conn.Close(); 
                SetBind(); 
            }

        }

    }

}

文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    相关网站:

    文章 下载 图片
    普通文章[组图]DataGrid在Po
    普通文章[图文]DataGrid的Ed
    普通文章[图文]方便的使用单
    普通文章[组图]为DataGrid添
    普通文章[组图]如何用DataGr
    普通文章[组图]嵌套的DataGr
    普通文章[组图]如何利用Data
    普通文章[组图]联合主键的情
  • 此栏目下没有推荐文章
  • 普通文章把手教你写私服列表
    普通文章WEB标准
    普通文章GOOGLE sitemap官方
    普通文章用php定制404错误页
    普通文章WAP(wml)开发问答
    普通文章[组图]PS教程系列:快
    普通文章时使用apache和IIS,
    普通文章[组图]2005年的第一
    推荐文章[组图]彻底掌握IIS6
    推荐文章[组图]CSS 全攻略
    推荐文章各种脚本错误详解!
    推荐文章直接生成XML的Googl
    推荐文章九个常见的错误原因
    推荐文章Win XP家用版也能装
    推荐文章JSP入门初级教程之J
    推荐文章ASP入门及提高
  • DataGrid在PostB

  • DataGrid的EditC

  • 方便的使用单击和

  • 为DataGrid添加自

  • 如何用DataGrid实


  • DataGrid在PostBack

    DataGrid的EditComm

    方便的使用单击和双

    为DataGrid添加自定
    (只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    Copyright © 2003-2005 NetBei.com All rights reserved.