数据分层

什么东西,自己以前写的一段代码,看了半天,大致了解。

 

大概是数据库中有一些数据,将这些字段安装某个自定义的数组顺序排列。用在什么情况,真的很难回想起来。

 

 

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
namespace TransLevel
{
   static  class TransLevel
    {
       /// <summary>
        /// 在表中增加一列 keyFiled + "level" 设定keyFiled的级别
       /// </summary>
       /// <param name="keyValuelist"></param>
       /// <param name="keylevellist"></param>
       /// <param name="keyFiled"></param>
       /// <param name="dt"></param>
       static public  void TransDt(double[] keyValuelist, string[] keylevellist, string keyFiled, DataTable dt)
        {
            if (!dt.Columns.Contains(keyFiled ))
            {
              return ;
            }

            if (!dt.Columns.Contains(keyFiled + "level"))
            {
                dt.Columns.Add(keyFiled + "level");
            }
           foreach (DataRow dr in dt.Rows)
            {
                try
                {
                    double cuurd = double.Parse(dr[keyFiled].ToString());
                    int nat = FindIndex(keyValuelist, cuurd);
                    if (nat >= 0)
                    {
                        dr[keyFiled + "level"] = keylevellist[nat];
                    }
                }
                catch
                {

                    dr[keyFiled + "level"] = "err";
                }
            }
        }


       /// <summary>
       /// 在数组中查找当前值的顺序
       /// </summary>
       /// <param name="aa"></param>
       /// <param name="currd"></param>
       /// <returns></returns>
    static    int FindIndex(double[] aa, double currd)
        {
            int nlen = aa.Length;
            if (nlen < 2)
            {
                return 0;
            }


            if (aa[0] < aa[1])//升序排列
            {

                for (int i = 0; i < nlen; i++)
                {
                    if (currd <= aa[i])
                    { return i; }
                }

            }
            else
            {

                for (int i = 0; i < nlen; i++)
                {
                    if (currd >= aa[i])
                    { return i; }
                }
            }
            return nlen - 1;

        }
    }
}

 

///

  double[] keyValuelist = new double[] { 300, 200, 54 };
            string[] keylevellist = new string[] { "a", "b", "c" };
            string keyFiled = "applyfee";

            DataTable dt = DBT.DAL.Query("select applyfee from f_applydetail where applyno='2008090390010014'").Tables[0];
          
       TransLevel.TransLevel.TransDt(keyValuelist, keylevellist, keyFiled, dt);  dataGridView1.DataSource = dt;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值