[c#基础]DataTable的Select方法

简介:

引言

可以说DataTable存放数据的一个离线数据库,将数据一下加载到内存,而DataReader是在线查询,而且只进形式的查询,如果后退一步,就不可能了,DataTable操作非常方便,但也有缺点,数据量非常大的时候,一下加载到内存,可想而知会有多么的卡了。这里只是说明DataTable的select()方法,具体项目根据需求,可以自己选择。

Select

既然DataTable是一下从数据库中拿数据,肯定提供了更方便的筛选方法,然后就找了一下,觉得Select能满足日常的筛选工作,做了一个小demo,测试了一下。

复制代码
 1 //
 2         // 摘要: 
 3         //     获取所有 System.Data.DataRow 对象的数组。
 4         //
 5         // 返回结果: 
 6         //     System.Data.DataRow 对象的数组。
 7         public DataRow[] Select();
 8         //
 9         // 摘要: 
10         //     获取按与筛选条件相匹配的所有 System.Data.DataRow 对象的数组。
11         //
12         // 参数: 
13         //   filterExpression:
14         //     要用来筛选行的条件。
15         //
16         // 返回结果: 
17         //     System.Data.DataRow 对象的数组。
18         public DataRow[] Select(string filterExpression);
19         //
20         // 摘要: 
21         //     获取按照指定的排序顺序且与筛选条件相匹配的所有 System.Data.DataRow 对象的数组。
22         //
23         // 参数: 
24         //   filterExpression:
25         //     要用来筛选行的条件。
26         //
27         //   sort:
28         //     一个字符串,它指定列和排序方向。
29         //
30         // 返回结果: 
31         //     与筛选表达式相匹配的 System.Data.DataRow 对象的数组。
32         public DataRow[] Select(string filterExpression, string sort);
33         //
34         // 摘要: 
35         //     获取与排序顺序中的筛选器以及指定的状态相匹配的所有 System.Data.DataRow 对象的数组。
36         //
37         // 参数: 
38         //   filterExpression:
39         //     要用来筛选行的条件。
40         //
41         //   sort:
42         //     一个字符串,它指定列和排序方向。
43         //
44         //   recordStates:
45         //     System.Data.DataViewRowState 值之一。
46         //
47         // 返回结果: 
48         //     System.Data.DataRow 对象的数组。
49         public DataRow[] Select(string filterExpression, string sort, DataViewRowState recordStates);
复制代码
复制代码
 1 using System;
 2 using System.Collections.Generic;
 3 using System.ComponentModel;
 4 using System.Data;
 5 using System.Drawing;
 6 using System.Linq;
 7 using System.Text;
 8 using System.Threading.Tasks;
 9 using System.Windows.Forms;
10 
11 namespace Wolfy.DatatableSelect
12 {
13     public partial class MainForm : Form
14     {
15         public MainForm()
16         {
17             InitializeComponent();
18         }
19         DataTable dt = null;
20         DataTable d = null;
21         private void btnSearch_Click(object sender, EventArgs e)
22         {
23             string where = string.Empty;
24             if (ckMan.Checked)
25             {
26                 where += "性别='男'";
27             }
28             else
29             {
30                 where = string.Empty;
31             }
32             if (ckCotainsW.Checked)
33             {
34                 where += ckMan.Checked ? " and 姓名 like '%w%'" : "姓名 like '%w%'";
35             }
36             
37             DataRow[] rows = dt.Select(where);
38             richTextResult.AppendText("编号\t姓名\t性别\t年龄\t\r\n");
39             for (int i = 0; i < rows.Length; i++)
40             {
41                 ShowSearchResult(rows[i]);
42             }
43 
44 
45 
46 
47         }
48         private void ShowSearchResult(DataRow row)
49         {
50             richTextResult.AppendText(string.Format("{0}\t{1}\t{2}\t{3}\t\r\n", row[0], row[1], row[2], row[3]));
51         }
52         private void MainForm_Load(object sender, EventArgs e)
53         {
54             dt = new DataTable();
55             DataColumn cell1 = new DataColumn("编号");
56             cell1.DataType = typeof(System.Int32);
57             DataColumn cell2 = new DataColumn("姓名");
58             cell2.DataType = typeof(System.String);
59             DataColumn cell3 = new DataColumn("性别");
60             cell3.DataType = typeof(System.String);
61             DataColumn cell4 = new DataColumn("年龄");
62             cell4.DataType = typeof(System.Int32);
63             dt.Columns.AddRange(new DataColumn[] { cell1, cell2, cell3, cell4 });
64 
65             Random ran = new Random();
66             string[] gender = { "", "", "保密" };
67             string[] names = { "韩梅梅", "wolfy", "小米", "w3w" };
68             for (int i = 0; i < 20; i++)
69             {
70                 int index = ran.Next(0, 3);
71                 DataRow row = dt.NewRow();
72                 row[0] = i;
73                 row[1] = names[ran.Next(0, 4)] + i.ToString();
74 
75                 row[2] = gender[index];
76                 row[3] = ran.Next(10, 50);
77                 dt.Rows.Add(row);
78             }
79             dgView.DataSource = dt;
80         }
81 
82 
83     }
84 }
复制代码

测试结果

总结

用select方法进行筛选还是非常方便的,以前的本方法就是遍历,然后将符合条件的数据取出,很麻烦。

博客地址: http://www.cnblogs.com/wolf-sun/
博客版权: 本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。
如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步!
再次感谢您耐心的读完本篇文章。

转载:http://www.cnblogs.com/wolf-sun/p/3560389.html
目录
相关文章
|
1月前
|
Java 调度 C#
C#学习系列相关之多线程(一)----常用多线程方法总结
C#学习系列相关之多线程(一)----常用多线程方法总结
|
1月前
|
C#
C#学习相关系列之数组---常用方法使用(二)
C#学习相关系列之数组---常用方法使用(二)
|
1月前
|
存储 C# 数据库
C# 生成唯一ID,有哪些方法?
【2月更文挑战第12天】
159 0
|
3月前
|
编译器 C# 开发者
C# 11.0中的新特性:覆盖默认接口方法
C# 11.0进一步增强了接口的灵活性,引入了覆盖默认接口方法的能力。这一新特性允许类在实现接口时,不仅可以提供接口中未实现的方法的具体实现,还可以覆盖接口中定义的默认方法实现。本文将详细介绍C# 11.0中接口默认方法覆盖的工作原理、使用场景及其对现有代码的影响,帮助开发者更好地理解和应用这一新功能。
|
3月前
|
安全 C# 开发者
C#中的默认接口方法:接口演化的新篇章
【1月更文挑战第11天】本文探讨了C# 8.0中引入的默认接口方法,这一特性允许在接口中定义具有默认实现的方法。文章介绍了默认接口方法的语法、使用场景,以及它们如何影响接口的设计和实现,同时讨论了默认接口方法带来的好处和潜在的陷阱。
|
4月前
|
缓存 C#
C# 操作路径(Path)类方法的使用与解析运行实例
C# 操作路径(Path)类方法的使用与解析运行实例
|
1月前
|
开发框架 .NET C#
C#学习相关系列之Linq用法---where和select用法(二)
C#学习相关系列之Linq用法---where和select用法(二)
|
1月前
|
C#
C#学习相关系列之数据类型类----嵌套类和嵌套方法(三)
C#学习相关系列之数据类型类----嵌套类和嵌套方法(三)
|
1月前
|
开发框架 .NET C#
C#学习相关系列之Linq常用方法---排序(一)
C#学习相关系列之Linq常用方法---排序(一)
|
1月前
|
开发框架 .NET 编译器
C#学习相关系列之匿名方法和Lambda表达式
C#学习相关系列之匿名方法和Lambda表达式