ASPNETDataset列名格式化
创始人
2024-09-20 09:30:36
0

在 ASP.NET 的 DataSet 中,列的名称默认情况下是不区分大小写的。在某些情况下,为了更方便地访问和识别列,可能需要将列名格式化为一致的大小写。下面是一种实现该功能的方法:

  1. 创建一个自定义的 DataSet 类,继承于系统自带的 DataSet 类。

  2. 在自定义的 DataSet 类中,重载 ColumnsChanged 事件处理函数。

  3. 在 ColumnsChanged 事件处理函数中,遍历 DataSet 的所有表和列,将列名格式化为一致的大小写。

示例代码如下:


public class MyDataSet : DataSet
{
   public MyDataSet() : base()
   {
      ColumnChanging += new System.Data.DataColumnChangeEventHandler(MyDataSet_ColumnChanging);
      ColumnsChanged += new System.EventHandler(MyDataSet_ColumnsChanged);
   }

   void MyDataSet_ColumnChanging(object sender, DataColumnChangeEventArgs e)
   {
      string newColumnName = e.ProposedValue.ToString();
      if (string.IsNullOrWhiteSpace(newColumnName))
         throw new ArgumentNullException("Column name can not be empty.");

      // Rename the duplicated columns by appending _1, _2, _3 and so on.
      int index = 1;
      while (e.Row.Table.Columns.Contains(newColumnName))
      {
         newColumnName = e.ProposedValue.ToString() + "_" + index.ToString();
         index++;
      }
      e.ProposedValue = newColumnName;
   }

   void MyDataSet_ColumnsChanged(object sender, EventArgs e)
   {
      // Format all the column names to the same case.
      foreach (DataTable table in Tables)
      {
         var columnNames = table.Columns.Cast().Select(c => c.ColumnName).Distinct();
         foreach (var columnName in columnNames)
         {
            var columns = table.Columns.Cast().Where(c => c.ColumnName.Equals(columnName, StringComparison.OrdinalIgnoreCase));
            if (columns.Count() > 1)
            {
               // There are duplicated columns with different cases.
               int index = 1;
               foreach (var column in columns)
               {
                  column.ColumnName = columnName + "_" + index.ToString();
                  index++;
               }
            }
            else
            {
               var column = columns.Single();
               column.ColumnName = columnName;
            }
         }
      }
   }
}

在上述示例代码中,我们通过重载 ColumnChanging 事件和 ColumnsChanged 事件实现了 DataSet 列名的格式化。在 ColumnChanging 事件处理函数中,我们将空列名和重复列名重命名为“columnName_1”,“columnName_2”等。在 ColumnsChanged 事件处理函数中,我们

相关内容

热门资讯

9分钟了解!至友互娱是不是有外... 9分钟了解!至友互娱是不是有外 挂,jj跑得快,德州论坛(有挂解密)1、下载好至友互娱是不是有外 挂...
三分钟了解!大唐河北麻将有挂吗... 三分钟了解!大唐河北麻将有挂吗,微信jj斗地主有挂吗,教你攻略(有挂辅助挂)1、让任何用户在无需大唐...
2分钟了解!壹起跑得快吗,陕麻... 2分钟了解!壹起跑得快吗,陕麻圈外挂,介绍教程(有挂插件)1、很好的工具软件,可以解锁游戏的壹起跑得...
十分钟了解!朋朋棋牌怎么拿好牌... 十分钟了解!朋朋棋牌怎么拿好牌,福建众娱软件辅助去哪里买,教你攻略(有挂秘笈);1、操作简单,无需注...
9分钟了解!经典联盟辅助器,家... 9分钟了解!经典联盟辅助器,家家乐牌吧吗,专业教程(有挂技巧)1、经典联盟辅助器透视辅助简单,经典联...
1分钟了解!微乐广西麻将跑得快... 1分钟了解!微乐广西麻将跑得快有挂的吗,瑞星游戏有挂吗,透明挂教程(有挂详情)1、不需要AI权限,帮...
两分钟了解!家家乐牌吧辅助,福... 两分钟了解!家家乐牌吧辅助,福建天天开心王国辅助器,分享教程(有挂秘笈)亲,关键说明,福建天天开心王...
三分钟了解!天天贵阳麻将助赢神... 三分钟了解!天天贵阳麻将助赢神器,辽宁心悦麻将有挂吗,解密教程(有挂教学)天天贵阳麻将助赢神器软件透...
五分钟了解!微信决胜麻将胡牌神... 五分钟了解!微信决胜麻将胡牌神器下载,中至南昌麻将丰城踢牌有挂吗,科技教程(有挂插件)1、全新机制【...
6分钟了解!陕西欢喜怎么开挂,... 6分钟了解!陕西欢喜怎么开挂,中至二人麻将有猫腻吗,曝光教程(有挂秘笈)1、中至二人麻将有猫腻吗ai...