WinForm中OleDbDataReader的问题

fywindy 2013-07-22 03:43:31
  public OleDbDataReader ExecuteQueryReturnReader(string sql, string connStr)
{
OleDbConnection conn = new OleDbConnection();
OleDbDataReader reader = null;
try
{
conn = new OleDbConnection(connStr);
conn.Open();

OleDbCommand command = conn.CreateCommand();
command.CommandText = sql;
reader = command.ExecuteReader();
}
catch
{
}
finally
{
if (conn != null)
conn.Close();
}
return reader;
}


以上是在下的代码,在项目中是这么使用的:

string DataBase = "HCConfig.mdb";
string strConnection = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="
+ Application.StartupPath + "//" + DataBase;
ExecSql con = new ExecSql();
string Sql= "select * form config where ID='sss'";
OleDbDataReader p = con.ExecuteQueryReturnReader(strConnection, Sql);
MessageBox.Show(p.FieldCount.ToString());

但是为什么会出现以下的错误?
其他信息: 未将对象引用设置到对象的实例。
每次执行到 MessageBox.Show(p.FieldCount.ToString());的时候总会出现这句话!!!!
...全文
103 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
fywindy 2013-07-22
  • 打赏
  • 举报
回复
结贴给分,单词拼错了!!!!!!!
happySnow_zhe 2013-07-22
  • 打赏
  • 举报
回复
好吧,刚回复一看你的SQL语句,我现在很肯定是你的OleDbDataReader的实例P为null了,你的SQL语句错误:select * form config where ID='sss' 中的form写错了!是from!!!导致P为null,那么你后面的获取其属性值肯定是未将对象引用到对象的实例了!
happySnow_zhe 2013-07-22
  • 打赏
  • 举报
回复
如果说楼上2为说的错误你修改好了还是报错,那么我只能想到的是你的数据库查询的问题了!你确定你执行SQL返回的OleDbDataReader的实例P不为null?
晓疯馋曰 2013-07-22
  • 打赏
  • 举报
回复
跟踪调试一下呗,看哪里出了错.
fywindy 2013-07-22
  • 打赏
  • 举报
回复
引用 4 楼 cqslzhao 的回复:
finally { if (conn != null) conn.Close(); } 连接已经在返回前关闭了. 这个不用自己写,已经有成熟的sqlhelper或oledbhelper.
去掉 if (conn != null) conn.Close();也不行我试过的
晓疯馋曰 2013-07-22
  • 打赏
  • 举报
回复
finally { if (conn != null) conn.Close(); } 连接已经在返回前关闭了. 这个不用自己写,已经有成熟的sqlhelper或oledbhelper.
fywindy 2013-07-22
  • 打赏
  • 举报
回复
引用 2 楼 guwei4037 的回复:
OleDbDataReader p = con.ExecuteQueryReturnReader(Sql,strConnection);//是不是传反了?
是我写反了,但是还是那个错误
全栈极简 2013-07-22
  • 打赏
  • 举报
回复
OleDbDataReader p = con.ExecuteQueryReturnReader(Sql,strConnection);//是不是传反了?
fywindy 2013-07-22
  • 打赏
  • 举报
回复
自己狂顶呀,千万别沉
本文介绍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编程的良好示例,例如添加数据时界面并没有很好地更新。

110,500

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

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