winform里程序多次读取数据库的问题?

hztltgg 2011-09-22 08:34:00
一个小程序,用access当数据库,界面有近20次的读取数据库,都是一些表格的绑定和统计数据的赋值,同时,界面还有维护功能,插入了数据还会重新读取数据。

我每次访问数据库,调用的都是独立的方法,类似于
Using conn As DbConnection = providerFactory.CreateConnection
conn.ConnectionString = connectionString
Using cmd As DbCommand = providerFactory.CreateCommand
conn.Open()
cmd.Connection = conn
cmd.CommandText = sql

。。。。。
。。。。。

End Using
End Using
这样似乎每次访问都是重新创建连接,一个界面刷新就要20次的打开和关闭连接了,这样设计是不是很不合理,要如何修改?有连接池的技术可以利用吗?
...全文
177 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
allanli 2011-09-25
  • 打赏
  • 举报
回复
你可以把你的多次查询合成一个批处理查询,返回多个表到DataSet中
然后自己在内存表再处理就可以了,这样可以减少查询次数,是可以加快速度的
枪牌 2011-09-22
  • 打赏
  • 举报
回复
楼主的程序不用改了
.net自身的数据库连接机制,当第二次以相同连接字符串连接数据库时自动创建数据库连接池
所以你看着是不断得断开重连,实际上已经用了连接池了
快溜 2011-09-22
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 sudianbo 的回复:]
可以程序一打开就连接,程序关闭前断开数据库。每次访问数据库都用这个全局的数据库连接。使用前判断一下,如连接偶尔断了,则重连
[/Quote]你这样才叫不合理,一个人独占一条连接,还要连接池干什么用。。。楼主的做法应该算是合理的,不必在意什么频繁访问数据库,数据库能做到的事情远远超过你的猜想
_三皮_ 2011-09-22
  • 打赏
  • 举报
回复
可以程序一打开就连接,程序关闭前断开数据库。每次访问数据库都用这个全局的数据库连接。使用前判断一下,如连接偶尔断了,则重连
hztltgg 2011-09-22
  • 打赏
  • 举报
回复
有不少是统计,输入一个产品代码,有不同的统计数据要显示,本月的,上月的,出库的,入库的,放在一个查询里太复杂了,单独统计条理比较清晰。
lmhcs 2011-09-22
  • 打赏
  • 举报
回复
一次刷新 要调用20多次?应该业务上设计不是很合理吧?我一次界面上的变动,一最多也是四五次sql。太多了,一定会影响性能,特别当数据库数据越多,应该越严重吧?
xiaoyu821120 2011-09-22
  • 打赏
  • 举报
回复
winform的程序不用太考虑数据库的问题,速度不慢就行。
暖枫无敌 2011-09-22
  • 打赏
  • 举报
回复
那你可以在连接字符串中指定max pool size,表示连接池中允许的最大连接数,默认为100。
也可以指定min pool size表示连接池中允许的最小连接数,默认为0。

一个页面20次不少不过也不多,数据库应该处理的过来。
「已注销」 2011-09-22
  • 打赏
  • 举报
回复
直接在DataGridView中操作不可以吗?为什么非要写繁杂的代码。。。
tigertang123 2011-09-22
  • 打赏
  • 举报
回复
用完关闭连接 正常。。。

ado.net 已经包含连接池相关应用机制,关闭连接并不是实际意义的断开连接,连接池会自动帮我们保持最小资源下的连接数据库~
本文介绍C#访问操作Access数据库的基础知识,并提供一个相关的例程。 1.通过ADO.NET的OleDb相关类来操作Access 主要知识点如下: using System.Data.OleDb; using System.Data; 连接字符串:String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=product.mdb"; 建立连接:OleDbConnection connection = new OleDbConnection(connectionString); 使用OleDbCommand类来执行Sql语句: OleDbCommand cmd = new OleDbCommand(sql, connection); connection.Open(); cmd.ExecuteNonQuery(); 2.取得Access自增标识字段在插入数据后的id值 cmd.CommandText = @"select @@identity"; int value = Int32.Parse(cmd.ExecuteScalar().ToString()); return value; 3.执行事务 需要用到OleDbTransaction,关键语句如下: OleDbConnection connection = new OleDbConnection(connectionString); OleDbCommand cmd = new OleDbCommand(); OleDbTransaction transaction = null; cmd.Connection = connection; connection.Open(); transaction = connection.BeginTransaction(); cmd.Transaction = transaction; cmd.CommandText=sql1; cmd.ExecuteNonQuery(); cmd.CommandText=sql2; cmd.ExecuteNonQuery(); transaction.Commit(); 4.执行查询,返回DataSet OleDbConnection connection = new OleDbConnection(connectionString); DataSet ds = new DataSet(); connection.Open(); OleDbDataAdapter da = new OleDbDataAdapter(sql, connection); da.Fill(ds,"ds"); 5.分页查询 分页查询使用OleDbDataReader来读取数据,并将结果写到一个DataSet中返回。 以上内容封装为三个可重用的类:AccessDBUtil,AccessPageUtil,Page 代码这下载AccessDBUtilDemo.rar (191.37 KB , 下载:999次) 本例程是一个c#的winform程序,但是数据访问类可以在Web环境下使用。 本例程演示了: 1.Access数据库的插入,更新,修改,查询; 2.带参数的sql语句的使用,而不是拼SQL; 3.使用DataReader的分页查询,而不是用嵌套的SQL语句来分页; 4.用事务同时执行多个SQL语句; 5.在插入数据的同时返回最新的ID值; 6.整型,实型,字符串,日期型,布尔型五种数据类型的操作; 7.使用正则表达式来验证整数和实数; 8.listview用来显示数据的一些基本用法。 本示例不包括: 1.高效的分页查询,仅仅是提供了一种分页的方法,但我认为DataReader应该比嵌套的SQL语句快(未测试)。 2.完善的分页封装,只提供了分页的简单包装。 3.嵌套的事务处理,提供了同时执行多个sql语句的事务处理,但不支持嵌套事务。 4.listview的使用,只是利用winform控件来演示数据访问,因此不能作为winform编程的良好示例,例如添加数据时界面并没有很好地更新。

16,555

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧