c#的winform通过webserver访问win2000server服务的sql2000数据库出现很奇怪的问题

kzlyan 2012-08-31 11:54:41
问题:
当版本验证查询TRVersion 表时,给出的查询结果datatable却是其他表的内容,
如果版本验证通过,下一次查询给出的结果却是第一次查询的datatable结果,单步调试无法跟踪到服务器的webserver中,实在是头疼呀,诚恳的请求各路大侠帮忙,感激不尽,
(单机调试无问题,就是连接上服务器才出现此问题)部分代码如下:
验证版本:
{
。。。
string sqlstr = "select top 1 Version from TRVersion order by Version desc";
dtb = Upublic.GetData(sqlstr);
。。。
}

public static DataTable GetData(string Sql)
{
DataTable dt = new DataTable();
string Exceptionstr = "";
DataSet ds = dblib.GetData(Sql, out Exceptionstr);
if (ds != null)
{
return ds.Tables[0];
}
MessageBox.Show(Exceptionstr);
return null;
}

放置在服务器的 DBLib.asmx的部分代码
private static SqlConnection SqlCon { get; set; }
private static string _SqlConStr;

private static string SqlConStr
{
get
{
if (string.IsNullOrEmpty(_SqlConStr) )
_SqlConStr= ConfigurationManager.AppSettings["ConnectionString"];

return _SqlConStr;
}
}

private bool GetCon()
{
//if (SqlCon != null)
// return true;
try
{
if (SqlCon == null)
{
SqlCon = new SqlConnection(SqlConStr);
SqlCon.Open();
return true;
}
else if (SqlCon.State == ConnectionState.Closed)
{
SqlCon.Open();
return true;
}
return true;
}
catch (Exception ex)
{
SqlCon = null;
throw ex;
}
}
[WebMethod]
public DataSet GetData(string Sql, out string ExceptionStr)
{
try
{
ExceptionStr = null;
if (!GetCon())
return null;
DataSet ds = new DataSet();
DataTable dt = new DataTable();
ds.Tables.Add(dt);
try
{
SqlCommand Command = new SqlCommand(Sql, SqlCon);
SqlDataAdapter adapter = new SqlDataAdapter(Command);
adapter.Fill(dt);
//SqlCon.Close();
return ds;
}
catch (Exception ex)
{
ExceptionStr = ex.Message;
return null;
}
}
finally
{
SqlCon.Close();
}
}
服务器winserver2000,数据库SQLserver2000,我在服务器的Internet的信息服务的虚拟站点里面建立了一个虚拟目录存放我的webserver文件,不知道是配置问题还是c#查询问题,实在是没有办法了,希望高手们指点,感觉呀
...全文
36 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

110,566

社区成员

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

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

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