在网站或应用程序中,要显示数据信息,可用到ASP.NET提供的数据源控件和能够显示数据的控件。

一、数据源控件

  数据源控件用于连接数据源、从数据源中读取数据以及把数据写入数据源。

1.数据源控件特点

  使用数据源控件可以不用编写任何代码就可以实现页面的数据绑定。

2.数据源控件的种类

  .NET框架提供了如下几个数据源控件:

  1. SqlDataSource,它用来访问存储在关系数据中的数据源,它与SQL Server一起使用时支持高级缓存功能。当数据作为DataSet对象返回时,此控件还支持排序、筛选和分页。
  2. AccessDataSource,它主要用来访问Microsoft Access数据库。当数据作为DataSet对象返回时,支持排序、筛选和分页。
  3. ObjectDataSource,它是表示具有数据检索和更新功能的中间层对象,允许使用业务对象或其他类,并可创建依赖中间层对象管理数据的Web应用程序。
  4. XmlDataSource,它主要用来访问XML文件,特别适用于分层的ASP.NET服务器控件,如TreeView或Menu控件。
  5. SiteMapDataSource,结合 ASP.NET 站点导航使用。
  6. LinqDataSource,使用 LinqDataSource 控件,可以在 ASP.NET 网页中使用 LINQ,从数据表或内存数据集合中检索数据。
  7. EntityDataSource,EntityDataSource 控件支持基于实体数据模型(EDM) 的数据绑定方案。此数据规范将数据表示为实体和关系集。它支持自动生成更新、插入、删除和选择命令以及排序、筛选和分页。

二、数据绑定控件

  数据绑定控件可以绑定到数据源控件,利用数据源控件提供的数据实现包括排序、分页、更新、删除和插入等对数据的操作功能,也可以通过编写代码实现。

1.数据绑定控件特点

  数据绑定控件通过DataSourceID属性连接到数据源控件。

2.数据源控件的种类

  常用的数据绑定控件有:

  1. GridView控件,以表格的形式显示数据,它是所有数据绑定控件中封装功能最多,最完善的一个控件,在不编写任务代码的情况下可以实现对数据进行技术检索、更新、删除、排序和分页等功能。也能运行代码绑定。
  2. DataList控件,使用不同的布局来显示数据记录,如将数据记录排成列或行。该控件提供了实现基本数据操作功能的常用命令,同时也提供了丰富的模板供用户使用。
  3. DetailsView控件,以表格形式显示数据,只是一次只能呈现一条记录,并提供翻阅多条记录以及插入、更新和删除记录功能。该控件通常和其他控件配合使用,如用GridView控件显示基本信息,用DetailsView控件显示相关的详细信息。
  4. FormView控件,与DetailsView控件类似,它一次呈现数据源的一条记录,并提供翻阅多条记录以及插入、更新和删除记录功能。FormView控件使用自定义布局,在布局时会更灵活些 。
  5. Repeater控件,以只读的方式显示多条记录,Repeater控件使用自定义布局。
  6. ListView控件,类似Repeater控件,它本身不提供分页功能,借助DataPage控件实现分页。

3.GridView控件

GridView控件的使用方式:

(1)通过任务编辑器操作GridView控件

(2)通过代码操作GridView控件

【例】通过代码操作GridView控件,实现数据的显示、删除、更新和分页功能。

-----【显示功能】

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;            //引入命名空间
using System.Data.SqlClient;  //引入命名空间
using System.Configuration;   //引入命名空间public partial class _2 : System.Web.UI.Page
{protected void Page_Load(object sender, EventArgs e){if(!IsPostBack){GetData();}}protected void GetData() {SqlConnection con = new SqlConnection();        //定义数据库连接对象con.ConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;  //定义数据库连接字符串SqlCommand com = new SqlCommand();              //定义数据库操作命令对象com.Connection = con;                           //连接数据库com.CommandText = "select CustomerID,CompanyName,ContactName,ContactTitle,Address from Customers"; //定义执行查询操作的sql语句SqlDataAdapter da = new SqlDataAdapter();       //创建数据适配器对象da.SelectCommand = com;                         //执行数据库操作命令DataSet ds = new DataSet();                     //创建数据集对象da.Fill(ds,"customers");                        //填充数据集GridView1.DataSource = ds.Tables["Customers"].DefaultView;//设置gridview控件的数据源为创建的数据集dsGridView1.DataBind();                           //绑定数据库表中数据
    }
}

运行结果:

-----【分页功能】

设置相关属性。在源视窗中手动添加 AllowPaging="True"   PageSize="8"

 <asp:GridView ID="GridView1" runat="server" AllowPaging="True" PageSize="8"AutoGenerateColumns="False" onpageindexchanging="GridView1_PageIndexChanging" ><Columns><asp:BoundField DataField="CustomerID" HeaderText="编号" /><asp:BoundField DataField="CompanyName" HeaderText="公司名称" /><asp:BoundField DataField="ContactName" HeaderText="联系人" /><asp:BoundField DataField="ContactTitle" HeaderText="联系人头衔 " /><asp:BoundField DataField="Address" HeaderText="地址" /></Columns></asp:GridView>

后台代码如下

protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e){GridView1.PageIndex = e.NewPageIndex;GetData();}

运行结果:

-----【选择、编辑、更新功能】

protected void GridView1_SelectedIndexChanging(object sender, GridViewSelectEventArgs e){GridView1.SelectedIndex = e.NewSelectedIndex; //实现选择功能
    }protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e){GridView1.EditIndex = e.NewEditIndex;  //实现编辑功能
        GetData();}protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e){GridView1.EditIndex = -1;//实现取消编辑功能
        GetData();}protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e){string customerId=GridView1.DataKeys[e.RowIndex][0].ToString();//取出修改行的主键值//取出修改后各字段的值string companyName = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[1].Controls[0])).ToString();string contactName = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[2].Controls[0])).ToString();string address = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[3].Controls[0])).ToString();string phone = ((TextBox)(GridView1.Rows[e.RowIndex].Cells[4].Controls[0])).ToString();//将用户更新的数据修改数据库SqlConnection con = new SqlConnection();        //定义数据库连接对象con.ConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;  //定义数据库连接字符串SqlCommand com = new SqlCommand();              //定义数据库操作命令对象com.Connection = con;                           //连接数据库string sql = "update Customers set CompanyName=@companyName,ContactName=@contactName,Address =@address, Phone=@phone where CustomerId =@customerId ";con.Open();SqlCommand cmd = new SqlCommand(sql, con);cmd.Parameters.AddWithValue("@companyName", companyName);cmd.Parameters.AddWithValue("@contactName", contactName);cmd.Parameters.AddWithValue("@address", address);cmd.Parameters.AddWithValue("@phone", phone);cmd.Parameters.AddWithValue("@customerId", customerId);com.CommandText = sql.ToString();com.ExecuteNonQuery();con.Close();GridView1.EditIndex = -1;GetData();}

-----【删除功能】

protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e){string customerId = GridView1.DataKeys[e.RowIndex][0].ToString();//取出修改行的主键值
            SqlConnection con = new SqlConnection();        //定义数据库连接对象con.ConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;  //定义数据库连接字符串SqlCommand com = new SqlCommand();              //定义数据库操作命令对象com.Connection = con;                           //连接数据库string sql = "delete from Customers  where CustomerId=@customerId";con.Open();SqlCommand cmd = new SqlCommand(sql, con);com.Parameters.AddWithValue("@customerId", customerId);com.ExecuteNonQuery();con.Close();GridView1.EditIndex = -1;GetData();    }

转载于:https://www.cnblogs.com/yankyblogs/p/6901716.html

数据绑定技术一:GridView控件相关推荐

  1. GridView控件详解

    GridView是ASP.NET 1.x的DataGrid控件的后继者.它提供了相同的基本功能集,同时增加了大量扩展和改进.如前所述,DataGrid(ASP.NET 2.0仍然完全支持)是一个功能非 ...

  2. [翻译]Scott Mitchell 的ASP.NET 2.0数据教程之十二:在GridView控件中使用TemplateField

    在ASP.NET 2.0中操作数据:在GridView控件中使用TemplateField 英文原版  |   本教程的代码(C#)   |   翻译目录   |   原文目录 导言 GridView ...

  3. Scott Mitchell 的ASP.NET 2.0数据教程之十二:在GridView控件中使用TemplateField

    导言 GridView是由一组字段(Field)组成的,它们都指定的了来自DataSource中的什么属性需要用到自己的输出呈现中.最简单的字段类型是BoundField,它仅将数据简单的显示为文本. ...

  4. 在ASP.NET 2.0中操作数据:在GridView控件中使用TemplateField

    英文原版  |   本教程的代码(C#)   |   翻译目录   |   原文目录 导言 GridView是由一组字段(Field)组成的,它们都指定的了来自DataSource中的什么属性需要用到 ...

  5. ASP.NET 2.0数据教程之十二:在GridView控件中使用TemplateField(转)

    导言 The GridView is composed of a set of fields that indicate what properties from the datasource are ...

  6. GridView控件修改、删除示例(修改含有DropDownList控件)

    GridView控件修改.删除例子,修改时含有DropDownList控件. 示例运行效果图: GridViewUp.aspx文件代码: <%@ Page Language="C#&q ...

  7. 在 GridView 控件中添加一列复选框51

    简介 在前面的教程中 , 我们学习了如何为 GridView 控件添加一列 单选 按钮来选择一个特定的记录.当用户被限制最多只能从网格中选中一项时,一列单选按钮是一个非常恰当的用户界面.然而,有时我们 ...

  8. 演练GridView控件显示目录图片

    本博文,将带你学习使用GridView控件显示站点目录的图片.如果你已经学会怎样做图片缩略图:怎样应用接口来实现统一的属性,方法或函数:怎样动态加载用户控件,等等.就不必往下看了.因为此篇博文就是演练 ...

  9. GridView控件常见问题及处理方法

    Asp.net 1.1版本中的DataGrid控件用于显示表格式的数据,相信大家都用过.Asp.net 2.0版本中GridView控件是DataGrid控件的继承者,功能比DataGrid增强不少, ...

最新文章

  1. js获取iframe中的元素_在 HTML 中包含资源的新思路
  2. sigmoid函数求导与自然指数
  3. 简练软考知识点整理-建设项目团队
  4. mybatis 调用存储过程
  5. golang之strings
  6. OpenStack回顾和展望-2018
  7. 高清卫星影像DEM数据免费下载,3款软件4个网站推荐收藏!
  8. 【PAT刷题甲级】部分笔记1065-1155~(下)
  9. 传奇服务器端显示时间问题,架设传奇出现is not a valid date and time时间错误
  10. 心得-计算机软考之嵌入式系统工程师
  11. 「津津乐道播客」#301 这是一期价值3000元的当代社畜科学点餐指南
  12. Java实现邮箱激活验证
  13. 运营日记:App推广手段详解
  14. VVIC搜款网平台API接口
  15. 低频RFID读卡流程
  16. 贪吃蛇c语言中加速怎么写,刚学C语言,想写一个贪吃蛇的代码
  17. 简洁安装HIT-SCIR(哈工大) pyltp
  18. 智能车跟随圆弧路径原理
  19. 超好用的画图工具推荐
  20. yolo模型是什么神经网络,yolo是卷积神经网络吗

热门文章

  1. Windows多线程(四) 经典线程同步 事件Event
  2. 又一新能源车企上市:九紫新能由热转冷,张水波身价三天缩水32亿
  3. 基于s3c2450 s5k5ca camera移植
  4. 计算机浮点数科学计数法运算,浮点数在计算机中的表示
  5. 中国婴儿果汁市场趋势报告、技术动态创新及市场预测
  6. 如何专心睡眠:当我们的思维停不下来的时候
  7. Adobe图片修复,去水印
  8. ChatGPT提问技巧 笔记
  9. 企业的信息化和数字化有什么区别
  10. 实力解剖一枚挖矿脚本,风骚操作亮瞎双眼