刚在做代码时,发现这样的一个问题

shoon0312 2012-08-27 01:57:38
DAL层
代码一:
/// 查找管理员
public DataTable SelectAllAdmin()
{
DataTable dt = new DataTable();
string cmdText = "select * from P_Admin";
dt = SQLHelper.ExecuteQuery(cmdText, CommandType.Text);
return dt;
}

sqlhelper类:
/// 执行不带参查询语句
public DataTable ExecuteQurey(string cmdText, CommandType ct)
{
DataTable dt = new DataTable();
cmd = new SqlCommand(cmdText, GetConn());
cmd.CommandType = ct;
using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
return dt;
}
代码二:
/// 执行不带参查询语句
public DataTable ExecuteQuery(string cmdText, CommandType ct)
{
DataTable dt = new DataTable();
cmd = new SqlCommand(cmdText, GetConn());
cmd.CommandType = ct;
using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
return dt;
}


这两段代码我比较过,完全是一样的,但在运行时去给出不同的错误。
代码一的错误:“ExecuteQuery”方法没有采用“2”个参数的重载
代码二的错误:非静态的字段、方法或属性“DLL.SQLHelper.ExecuteQuery(string, System.Data.CommandType)”要求对象引用
这是怎么回事呀,同样的代码怎么会出现不同的错误提示呢,还有这代码要怎么写才正确
...全文
76 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
正在加载昵称 2012-08-27
  • 打赏
  • 举报
回复

public static DataTable ExecuteQurey(string cmdText, CommandType ct)
{
DataTable dt = new DataTable();
cmd = new SqlCommand(cmdText, GetConn());
cmd.CommandType = ct;
using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr);
}
return dt;
}

static 静态方法,才能直接用类名调用,否则需要实例调用
杰拉尔 2012-08-27
  • 打赏
  • 举报
回复

//不是静态的要实例化调用
1可以加上 public static
2
sqlhelper sh=new sqlhelper();
sh.ExecuteQuery()


  • 打赏
  • 举报
回复
dt = SQLHelper.ExecuteQuery(cmdText, CommandType.Text);
=>
dt = SQLHelper.ExecuteQuery(cmdText, CommandType);

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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