首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > C# >

求解DataTable.Select()查询结果不一样?该怎么解决

2013-04-20 
求解DataTable.Select()查询结果不一样?static void Main(string[] args){DataColumn dc1 new DataColum

求解DataTable.Select()查询结果不一样?

static void Main(string[] args)
        { 
            DataColumn dc1 = new DataColumn("c1", typeof(System.Double));
            DataColumn dc2 = new DataColumn("c2", typeof(System.Double));
            DataColumn dc3 = new DataColumn("c3", typeof(System.Double));
            DataColumn dc4 = new DataColumn("c4", typeof(System.Double));

            DataTable dt = new DataTable();
            dt.Columns.Add(dc1);
            dt.Columns.Add(dc2);
            dt.Columns.Add(dc3);
            dt.Columns.Add(dc4);
             
            DataRow dr = dt.NewRow();
            dr["c1"] = 6164.97;
            dr["c2"] = 3164.97;
            dr["c3"] = 3000.0;
            dr["c4"] = 0.0;
            dt.Rows.Add(dr);
            dt.AcceptChanges();

            DataRow[] dsx = dt.Select("c1=c2+c3+c4");
            
            DataRow[] dsx1 = dt.Select("6164.97=3164.97+3000.0+0.0");
            //为什么这两个Select查询出来的结果不一样


            Console.Read();
        }
Select DataTable DataTable.Select
[解决办法]
6164.97=3164.97+3000.0+0.0 是常量表达式 为真的话 就不过滤数据了 所以还是一条



dt.Select("c1=c2+c3+c4"); 不知道 这个是是否支持 但可以换一种思路 如果从数据库返回数据
可以先判读是否相等 返回一个标识  比如( case when (c1=c2+c3+c4) then '1' else '0' end) flag

如果手动创建 那道理也一样 编码实现就是了
然后判断 dt.Select("flag='1'")
[解决办法]
            DataColumn dc1 = new DataColumn("c1", typeof(System.Decimal));
            DataColumn dc2 = new DataColumn("c2", typeof(System.Decimal));
            DataColumn dc3 = new DataColumn("c3", typeof(System.Decimal));


            DataColumn dc4 = new DataColumn("c4", typeof(System.Decimal));
            DataColumn dc5 = new DataColumn("c5", typeof(System.Decimal));            dc5.Expression = "c1=c2+c3+c4";

            DataTable dt = new DataTable();
            dt.Columns.Add(dc1);
            dt.Columns.Add(dc2);
            dt.Columns.Add(dc3);
            dt.Columns.Add(dc4);
            dt.Columns.Add(dc5);

            DataRow dr = dt.NewRow();
            dr["c1"] = 6164.97;
            dr["c2"] = 3164.97;
            dr["c3"] = 3000.00;
            dr["c4"] = 0;
            dt.Rows.Add(dr);
            dt.AcceptChanges();
            DataRow[] dsx = dt.Select("c5=1");

            DataRow[] dsx1 = dt.Select("6164.97=3164.97+3000.0+0.0");

数据类型问题.

热点排行