1. 在数据层分页数据。可以通过ExcuteReader或者存储过程实现等。
2. 尽量使用ExcuteReader来读取数据,ExcuteReader是效率最高的,在MicroSoft的PetShop 4.0全部数据访问都是用ExcuteReader来实现的,除非你对非连接有特殊要求(如 SmartClient智能客户端等)。
3. 在非连接场合,用DataTable比用DataSet性能好,除非你要保存多个关系表。
4. 使用DataTable的ImportRow方法。
有些场合需要把大量数据从一个DataTable复制到另一个DataTable,使用DataTable的ImportRow方法可以大大提高性能,数据量少时没多大分别,当数据量到一万行以上时就可以明显的提高,可以达到几倍。
5. 把数据序列化为二进制文件方便传输。
我们在处理DataSet,DataTable对象时可以序列化为XML文件,如果要在网络传输,XML文件会产生内存,网络带宽等资源问题。这时我们就可以把它序列化为二进制文件,这样生成的文件会减少很多,代码如下:
FileStream fs = new fileStream(@"XMLData.bin",FileMode.Create);
BinaryFormatter bf = new BinaryFormatter();
bf.Serialize(fs,XMLData);
fs.colse();
这样生成的二进制文件称为XMLBinary,用WINHEX直接打开还可以看到一些XML标记在里面,如果数据量很大,这时加一行代码:
XMLData.RemortingFormat = SerializationFormat.Binary;
这时生成的文件称为TrueBinary文件,当处理大量(超过10000行)时生成的文件尺寸是XMLBinary的几分之一。序列化的时候会自动保存模式,这样解序过程很简单。我还不知道解序比直接读取XML性能会下降多少。
6. 合理利用连接池。
连接池对性能的提高有很大的作用,默认是打开的。默认的Min Pool Size是0,一般设为一个比较小的值,如5。Max Pool Size默认是100,大多数WEB站点也够用,大型的适当增大。
7. 使用SQLCLR开发
如果你是专注开SQL Server系列那你应该去研究一下SQLCLR,它的功能非常强大,在很多场合都可以提高性能(特别是大型企业级应用)。
8. 通过静态类来访问APP.Config/Web.Config
我们有很多配置信息都是放在APP.Config/Web.Config,访问都会很频繁,这时建立一个静态类,所有的属性都通过静态类来访问,可以在一定程度提高性能,静态类只实例化一次,而APP.Config/Web.Config会产生很多IO操作。
2. 尽量使用ExcuteReader来读取数据,ExcuteReader是效率最高的,在MicroSoft的PetShop 4.0全部数据访问都是用ExcuteReader来实现的,除非你对非连接有特殊要求(如 SmartClient智能客户端等)。
3. 在非连接场合,用DataTable比用DataSet性能好,除非你要保存多个关系表。
4. 使用DataTable的ImportRow方法。
有些场合需要把大量数据从一个DataTable复制到另一个DataTable,使用DataTable的ImportRow方法可以大大提高性能,数据量少时没多大分别,当数据量到一万行以上时就可以明显的提高,可以达到几倍。
5. 把数据序列化为二进制文件方便传输。
我们在处理DataSet,DataTable对象时可以序列化为XML文件,如果要在网络传输,XML文件会产生内存,网络带宽等资源问题。这时我们就可以把它序列化为二进制文件,这样生成的文件会减少很多,代码如下:
FileStream fs = new fileStream(@"XMLData.bin",FileMode.Create);
BinaryFormatter bf = new BinaryFormatter();
bf.Serialize(fs,XMLData);
fs.colse();
这样生成的二进制文件称为XMLBinary,用WINHEX直接打开还可以看到一些XML标记在里面,如果数据量很大,这时加一行代码:
XMLData.RemortingFormat = SerializationFormat.Binary;
这时生成的文件称为TrueBinary文件,当处理大量(超过10000行)时生成的文件尺寸是XMLBinary的几分之一。序列化的时候会自动保存模式,这样解序过程很简单。我还不知道解序比直接读取XML性能会下降多少。
6. 合理利用连接池。
连接池对性能的提高有很大的作用,默认是打开的。默认的Min Pool Size是0,一般设为一个比较小的值,如5。Max Pool Size默认是100,大多数WEB站点也够用,大型的适当增大。
7. 使用SQLCLR开发
如果你是专注开SQL Server系列那你应该去研究一下SQLCLR,它的功能非常强大,在很多场合都可以提高性能(特别是大型企业级应用)。
8. 通过静态类来访问APP.Config/Web.Config
我们有很多配置信息都是放在APP.Config/Web.Config,访问都会很频繁,这时建立一个静态类,所有的属性都通过静态类来访问,可以在一定程度提高性能,静态类只实例化一次,而APP.Config/Web.Config会产生很多IO操作。