连接已打开

xqqsm 2010-08-23 08:39:34
做了一个登录的例子,发布在iis上,偶尔会报错,“连接SqlDataReader已打开,请先关闭”,刷新下页面它就能正常登录了,请问大虾们能不能帮我分析是什么原因,
这个是web.config里面连接池的配置
<connectionStrings>
<add name="dbconn" connectionString="Data Source=.;Initial Catalog=DatabaseName;uid=sa;pwd=1;Max Pool size=100000;Min Pool Size=0;Connection Lifetime=0;packet size=32767;Connection Reset=false; async=true;" providerName="System.Data.SqlClient"/>
</connectionStrings>

这个是登录的代码:
SqlDataReader sdr = SQLHelper.ExecuteReader("CheckAdmin", para);
if (sdr.Read())
{
user = new UserInf();
user.ID = int.Parse(sdr["id"].ToString());
}
sdr.Close();
...全文
89 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
hitlcyu19 2010-08-23
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 q107770540 的回复:]

参考此种格式来书写代码
C# code

string queryString =
"SELECT OrderID, CustomerID FROM dbo.Orders;";

using (SqlConnection connection =
new SqlConnection(connectionString))
{
……
[/Quote]
对 using
xqqsm 2010-08-23
  • 打赏
  • 举报
回复
有的时候不会错,偶尔会出现这个情况
xqqsm 2010-08-23
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 porschev 的回复:]
我也觉得问题不是出LZ帖出来的代码

应该是之前的操作留下的来打开之后未关闭
[/Quote]
没有之前的代码,这个方法就这么长
zcfzcf001 2010-08-23
  • 打赏
  • 举报
回复
支持4楼的见解
wuyq11 2010-08-23
  • 打赏
  • 举报
回复
SqlDataReader 要先关闭,再执行ExecuteNonQuery操作
dr.Read();
或using (SqlConnection cn = new SqlConnection(“”))
{
SqlCommand cmd1 = new SqlCommand("", cn);
cn.Open();
using (SqlDataReader dr1 = cmd1.ExecuteReader())
{
while (dr1.Read())
{
string sql= "";
SqlConnection conn2 = new SqlConnection("");
SqlCommand cmd2 = new SqlCommand(sql, conn2 );
cmd2.ExecuteNonQuery();
}
}

}
porschev 2010-08-23
  • 打赏
  • 举报
回复
我也觉得问题不是出LZ帖出来的代码

应该是之前的操作留下的来打开之后未关闭
xqqsm 2010-08-23
  • 打赏
  • 举报
回复
方法中的连接都检查过了,都是开完了就关的,不存在问题,因为 好几个程序都用的这个方法,别的项目一点问题都没有,就这个出问题了,不知道什么原因
baifudage 2010-08-23
  • 打赏
  • 举报
回复
4楼的说法是正解 你检查下你的程序吧。。。。。
Peter200694013 2010-08-23
  • 打赏
  • 举报
回复
在程序中找找看,是不是某个SqlDataReader忘记close了?
q107770540 2010-08-23
  • 打赏
  • 举报
回复
参考此种格式来书写代码

string queryString =
"SELECT OrderID, CustomerID FROM dbo.Orders;";

using (SqlConnection connection =
new SqlConnection(connectionString))
{
SqlCommand command =
new SqlCommand(queryString, connection);
connection.Open();

SqlDataReader reader = command.ExecuteReader();

// Call Read before accessing data.
while (reader.Read())
{
Console.WriteLine(String.Format("{0}, {1}",
reader[0], reader[1]));
}

// Call Close when done reading.
reader.Close();
}
回头是岸 2010-08-23
  • 打赏
  • 举报
回复
sdr.Close();
把这个放在finally中就可以啦
回头是岸 2010-08-23
  • 打赏
  • 举报
回复
像这种清空你最好用try_catch_finally

这样就不会出错
本课程是一门具有很强实践性质的“项目实战”课程,即“企业中台系统实战”,其中主要包含三大块核心内容,如下图所示(右键可以在新标签页中打开图片放大查看): 即主要包含以下三大块内容: ① 企业内部应用系统菜单资源和操作权限的统一管理; ② 分布式应用系统通信时的统一授权,即基于AccessToken的授权与认证; ③ 分布式服务/系统通信时的两大方式(基于dubbo rpc协议和基于http协议的restful api实战)。   值得一提的是,这套中台系统由于讲解了如何统一管理企业内部各大应用系统的“菜单资源列表”、“操作权限”,故而本门课程的“代码实战”是建立在之前debug录制的“企业权限管理平台”这套课程的基础之上的,故而在这里debug建议没有项目开发基础的小伙伴可以先去学习我的那套“企业权限管理平台”的实战课程,之后再来学习我的这套中台系统的实战才不会很吃力(课程链接:)   本课程的课程大纲如下图所示(右键可以在新标签页中打开图片放大查看):   除此之外,这套“中台系统”由于统一管理了企业内部各大应用系统的“菜单资源和操作权限”以及“应用系统之间通信时的统一授权”,故而难免需要涉及到“中台系统”与“中台子系统”、“中台子系统”与“中台子系统”之间的通信(即分布式服务之间的通信),在这里我们是采用“dubbo + zookeeper”的方式加以落地实现的,详情如下图所示(右键可以在新标签页中打开图片放大查看):   而众所周知,作为一款知名以及相当流行的分布式服务调度中间件,dubbo现如今已经晋升为Apache顶级的开源项目,未来也仍将成为“分布式系统”开发实战的一大利器,如下图所示为dubbo底层核心系统架构图(右键可以在新标签页中打开图片放大查看): 而在这门“中台系统实战”的课程中,我们也将始终贯彻、落地dubbo的这一核心系统架构图,即如何将中台系统开发的服务注册/发布到注册中心zookeeper,中台子系统如何订阅/消费/调度中台系统发布在zookeeper的接口服务,中台子系统在走http协议调度通信时dubbo如何进行拦截、基于token认证接口的调用者等等,这些内容我们在课程中将一一得到代码层面的实战落地!   下图为本课程中涉及到的分布式系统/服务之间 采用“http协议restfulapi”方式通信时的Token授权、认证的流程图(右键可以在新标签页中打开图片放大查看): 而不夸张地说,基于AccessToken的授权、认证方式在现如今微服务、分布式时代系统与系统在通信期间最为常用的“授权方式”了,可想而知,掌握其中的流程思想是多么的重要!   以下为本门课程的部分截图(右键可以在新标签页中打开图片放大查看):     核心技术列表: 值得一提的是,由于本门课程是一门真正介绍“中台思想”以及将“中台思想”和“分布式系统开发实战”相结合落地的课程,故而在学完本门课程之后,可以掌握到的核心技术自然是相当多的。主要由SpringBoot2.0、SpringMVC、Mybatis、Dubbo、ZooKeeper、Redis、OkHttp3、Guava-Retrying重试机制、JWT(Json Web Token)、Shiro、分布式集群session共享、Lombok、StreamAPI、Dubbo-Filter以及ServiceBean等等。如下图所示(右键可以在新标签页中打开图片放大查看):

110,538

社区成员

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

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

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