在Gridview如何进行每行单元格比较
有在论坛上看到一个问题,就是在Gridview控件中,需要对几个列的数值进行比较,原问题如下:
先在数据库中准备数据:

CREATE TABLE [dbo].[RecordTime] ( Id INT IDENTITY(1,1) PRIMARY KEY, Time1 DATETIME, Time2 DATETIME, Time3 DATETIME, Time4 DATETIME ) GO INSERT INTO [dbo].[RecordTime] VALUES ('2015-05-11 09:48','2015-05-20 10:08','2015-05-13 14:48','2015-05-19 08:48'), ('2015-05-10 14:48','2015-05-01 10:02','2015-05-20 12:48','2015-05-20 10:20'), ('2015-05-20 10:31','2015-05-03 10:40','2015-05-14 10:40','2015-05-25 09:48') GO CREATE PROCEDURE [dbo].[usp_RecordTime_GetAll] AS SELECT [Id],[Time1],[Time2],[Time3],[Time4] FROM [dbo].[RecordTime] GO
然后可以在.aspx.cs代码页中实现OnRowDataBound="GridView1_RowDataBound"事件:
.aspx.cs代码:

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using Insus.NET; using System.Data; using System.Drawing; public partial class _Default : System.Web.UI.Page { RecordTime rt = new RecordTime(); protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) Data_Binding(); } private void Data_Binding() { this.GridView1.DataSource = rt.GetRecordTime(); this.GridView1.DataBind(); } protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e) { if (e.Row.RowType != DataControlRowType.DataRow) return; DataRowView drv = (DataRowView)e.Row.DataItem; List<DateTime> lDT = new List<DateTime>(); lDT.Add(Convert.ToDateTime(drv["Time1"])); lDT.Add(Convert.ToDateTime(drv["Time2"])); lDT.Add(Convert.ToDateTime(drv["Time3"])); lDT.Add(Convert.ToDateTime(drv["Time4"])); DateTime dt = lDT.Max<DateTime>(); int i = lDT.IndexOf(dt); int actualIdx = i + 1; e.Row.Cells[actualIdx].ForeColor = Color.FromName("red"); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
2014-06-12 学习使用MS SQL Server游标(CURSOR)
2012-06-12 将Excel上传至MS SQL Server