当前位置: 首页 > news >正文

[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);
Select
 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方法进行筛选还是非常方便的,以前的本方法就是遍历,然后将符合条件的数据取出,很麻烦。

转载于:https://www.cnblogs.com/wolf-sun/p/3560389.html

相关文章:

  • Hibernate 缓存
  • ESXi 5.0 环境下安装部署Cisco Nexus 1000v
  • Python之内置函数
  • Lucene知识小总结7:评分设置
  • Rust语言:安全地并发
  • python基础===python中文手册
  • 便是管理,不是管理
  • 6-1 接口的特性
  • 驱动和应用层的三种通信方式
  • 《Java编程思想》笔记03------访问权限控制
  • 记笔记与博客
  • 树的遍历
  • 菜鸟配置SAMBA服务之1
  • Qt动态设置布局中的控件
  • CISCO无线AP胖瘦升级
  • JavaScript-如何实现克隆(clone)函数
  • 【347天】每日项目总结系列085(2018.01.18)
  • 【JavaScript】通过闭包创建具有私有属性的实例对象
  • Android开源项目规范总结
  • Java 最常见的 200+ 面试题:面试必备
  • JavaScript 基本功--面试宝典
  • JavaScript标准库系列——Math对象和Date对象(二)
  • Java精华积累:初学者都应该搞懂的问题
  • oldjun 检测网站的经验
  • PAT A1120
  • redis学习笔记(三):列表、集合、有序集合
  • 爱情 北京女病人
  • 从PHP迁移至Golang - 基础篇
  • 发布国内首个无服务器容器服务,运维效率从未如此高效
  • 解决iview多表头动态更改列元素发生的错误
  • 容器服务kubernetes弹性伸缩高级用法
  • 使用Swoole加速Laravel(正式环境中)
  • 微信支付JSAPI,实测!终极方案
  • 我建了一个叫Hello World的项目
  • puppet连载22:define用法
  • ​【已解决】npm install​卡主不动的情况
  • $.type 怎么精确判断对象类型的 --(源码学习2)
  • (173)FPGA约束:单周期时序分析或默认时序分析
  • (4)事件处理——(6)给.ready()回调函数传递一个参数(Passing an argument to the .ready() callback)...
  • (多级缓存)多级缓存
  • (二)构建dubbo分布式平台-平台功能导图
  • (附源码)ssm航空客运订票系统 毕业设计 141612
  • (附源码)ssm考试题库管理系统 毕业设计 069043
  • (附源码)计算机毕业设计高校学生选课系统
  • (十)c52学习之旅-定时器实验
  • (四) 虚拟摄像头vivi体验
  • (推荐)叮当——中文语音对话机器人
  • (详细版)Vary: Scaling up the Vision Vocabulary for Large Vision-Language Models
  • (一)C语言之入门:使用Visual Studio Community 2022运行hello world
  • (一一四)第九章编程练习
  • (原)Matlab的svmtrain和svmclassify
  • (转)我也是一只IT小小鸟
  • (总结)Linux下的暴力密码在线破解工具Hydra详解
  • ***原理与防范
  • **python多态