ExecuteReader: CommandText 属性尚未初始化

KerryMo 2009-04-05 09:55:27
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;

/// <summary>
/// CommonClass 的摘要说明
/// </summary>
public class CommonClass
{
public CommonClass()
{
//
// TODO: 在此处添加构造函数逻辑
//
}
/// <summary>
/// 连接数据库
/// </summary>
/// <returns>返回SqlConnection对象</returns>
public SqlConnection GetConnection()
{
string myStr = ConfigurationManager.AppSettings["ConnectionString"].ToString();
SqlConnection myConn = new SqlConnection(myStr);
return myConn;
}
/// <summary>
/// 说明:MessageBox用来在客户端弹出对话框。
/// 参数:TxtMessage 对话框中显示的内容。
/// 参数:Url 对话框关闭后,跳转的页
/// </summary>
public string MessageBox(string TxtMessage,string Url)
{
string str;
str = "<script language=javascript>alert('" + TxtMessage + "');location='" + Url + "'</script>";
return str;
}
/// <summary>
/// 说明:MessageBox用来在客户端弹出对话框。
/// 参数:TxtMessage 对话框中显示的内容。
/// </summary>
public string MessageBox(string TxtMessage)
{
string str;
str = "<script language=javascript>alert('" + TxtMessage + "')</script>";
return str;
}

/// <summary>
/// 说明:ExecSQL用来执行SQL语句。
/// 返回值:操作是否成功(True\False)。
/// 参数:sqlStr SQL字符串
/// </summary>
public Boolean ExecSQL(string sqlStr)
{
SqlConnection myConn = GetConnection();
myConn.Open();
SqlCommand myCmd = new SqlCommand(sqlStr, myConn);
try
{
myCmd.ExecuteNonQuery();
myConn.Close();
}
catch
{
myConn.Close();
return false;
}
return true;
}
/// <summary>
/// 说明:GetDataSet数据集,返回数据源的数据集
/// 返回值:数据集DataSet
/// 参数:sqlStr SQL字符串,TableName 数据表名称
/// </summary>
public System.Data.DataSet GetDataSet(string sqlStr, string TableName)
{
SqlConnection myConn =GetConnection();
myConn.Open();
SqlDataAdapter adapt = new SqlDataAdapter(sqlStr, myConn);
DataSet ds = new DataSet();
adapt.Fill(ds, TableName);
myConn.Close();
return ds;
}
/// <summary>
/// 防止SQL 注入式攻击
///
/// </summary>
/// <param name="loginName">用户登录名称</param>
/// <param name="loginPwd">用户登录密码</param>
public int checkLogin(string loginName, string loginPwd)
{
SqlConnection myConn = GetConnection();
SqlCommand myCmd = new SqlCommand("select count(*) from tb_User where Name=@loginName and PassWord=@loginPwd", myConn);
myCmd.Parameters.Add(new SqlParameter("@loginName", SqlDbType.VarChar, 20));
myCmd.Parameters["@loginName"].Value = loginName;
myCmd.Parameters.Add(new SqlParameter("@loginPwd", SqlDbType.VarChar, 50));
myCmd.Parameters["@loginPwd"].Value = loginPwd;
myConn.Open();
int i = (int)myCmd.ExecuteScalar();
myCmd.Dispose();
myConn.Close();
return i;
}
/// <summary>
/// 实现随机验证码
/// </summary>
/// <param name="n">显示验证码的个数</param>
/// <returns>返回生成的随机数</returns>
public string RandomNum(int n) //
{
//定义一个包括数字、大写英文字母和小写英文字母的字符串
string strchar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z";
//将strchar字符串转化为数组
//String.Split 方法返回包含此实例中的子字符串(由指定Char数组的元素分隔)的 String 数组。
string[] VcArray = strchar.Split(',');
string VNum = "";
//记录上次随机数值,尽量避免产生几个一样的随机数
int temp = -1;
//采用一个简单的算法以保证生成随机数的不同
Random rand = new Random();
for (int i = 1; i < n + 1; i++)
{
if (temp != -1)
{
//unchecked 关键字用于取消整型算术运算和转换的溢出检查。
//DateTime.Ticks 属性获取表示此实例的日期和时间的刻度数。
rand = new Random(i * temp * unchecked((int)DateTime.Now.Ticks));
}
//Random.Next 方法返回一个小于所指定最大值的非负随机数。
int t = rand.Next(61);
if (temp != -1 && temp == t)
{
return RandomNum(n);
}
temp = t;
VNum += VcArray[t];
}
return VNum;//返回生成的随机数
}

}
...全文
1793 18 打赏 收藏 转发到动态 举报
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
wangguolong888 2010-07-18
  • 打赏
  • 举报
回复
朋友,一定是Session["search"]的值还没有传过来!
wuyq11 2009-04-05
  • 打赏
  • 举报
回复
SqlConnection myConn 定义成全局变量
可参考sqlhelper
KerryMo 2009-04-05
  • 打赏
  • 举报
回复
[Quote=引用 15 楼 sq_zhuyi 的回复:]
Session["search"] == null

使用前确保Session["search"]存在
[/Quote]
这个要怎么看呢
路人乙e 2009-04-05
  • 打赏
  • 举报
回复
Session["search"] == null

使用前确保Session["search"]存在
zhangjie_it 2009-04-05
  • 打赏
  • 举报
回复
没有显示sqlstr的值,就说明是空值!
this.dlNews.DataSource = CC.GetDataSet(Convert.ToString(Session["search"]), "tbNews");

在你按查询按钮的时候,你要确保Convert.ToString(Session["search"]能得到查询条件!
KerryMo 2009-04-05
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 zhangjie_it 的回复:]
调试的时候,得到的sqlstr的值是什么?
[/Quote]
就是显示有错误,没有显示sqlstr的值
zhangjie_it 2009-04-05
  • 打赏
  • 举报
回复
你的问题是你获取的查询字符串不符合sql语法!

你先确保你的sql语句没有问题!

你的问题也就解决了!
KerryMo 2009-04-05
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 teerhu 的回复:]
public DataTable GetMyTable(string strCmd, string strConnection)
{

SqlDataAdapter da = new SqlDataAdapter(strCmd, strConnection);
da.SelectCommand.CommandTimeout = 240;
DataSet ds = new DataSet();
da.Fill(ds);
da.Dispose();
return ds.Tables[0];
}
我的也这么写的啊,你 看看sqlStr值传进去了没
要不拆开SqlDataAdapter ad…
[/Quote]
这样修改后提示错误:找不到类型或命名空间名称“adapt”(是否缺少 using 指令或程序集引用?)



zhangjie_it 2009-04-05
  • 打赏
  • 举报
回复
调试的时候,得到的sqlstr的值是什么?
KerryMo 2009-04-05
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 guzhonghua 的回复:]
public System.Data.DataSet GetDataSet(string sqlStr, string TableName)
{
SqlConnection myConn =GetConnection();
myConn.Open();
SqlDataAdapter adapt = new SqlDataAdapter(sqlStr, myConn);
DataSet ds = new DataSet();
adapt.Fill(ds, TableName);
myConn.Close();
return ds; }
这个错误是你传过来的查询字符串有问题啊,
还有我…
[/Quote]
在查询分析器里面执行了下说:'sqlstr' 附近有语法错误。
传过来的查询字符串有问题,,这样的问题要在哪里修改啊,刚开始学,不好意思
teerhu 2009-04-05
  • 打赏
  • 举报
回复
public DataTable GetMyTable(string strCmd, string strConnection)
{

SqlDataAdapter da = new SqlDataAdapter(strCmd, strConnection);
da.SelectCommand.CommandTimeout = 240;
DataSet ds = new DataSet();
da.Fill(ds);
da.Dispose();
return ds.Tables[0];
}
我的也这么写的啊,你 看看sqlStr值传进去了没
要不拆开SqlDataAdapter adapt = new SqlDataAdapter(sqlStr, myConn);
成 SqlDataAdapter adapt = new SqlDataAdapter();
adapt.CommandText sqlStr;
adapt.Connection =myConn;
guzhonghua 2009-04-05
  • 打赏
  • 举报
回复
public System.Data.DataSet GetDataSet(string sqlStr, string TableName)
{
SqlConnection myConn =GetConnection();
myConn.Open();
SqlDataAdapter adapt = new SqlDataAdapter(sqlStr, myConn);
DataSet ds = new DataSet();
adapt.Fill(ds, TableName);
myConn.Close();
return ds; }

这个错误是你传过来的查询字符串有问题啊,
还有我提示你一下,你如果用DataAdatper来填充数据的话,就不要在把Connection手动的打开或关闭了。
因为Adapter会自动的进行打开和关闭的。


zhangjie_it 2009-04-05
  • 打赏
  • 举报
回复
先在这里设置断点,看看传过去的是什么值?
先把这个sqlstr在查询分析器中执行以下,看是否对头?
KerryMo 2009-04-05
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zhangjie_it 的回复:]
你在哪里调用了这个函数:
public System.Data.DataSet GetDataSet(string sqlStr, string TableName)
{}
[/Quote]
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class search : System.Web.UI.Page
{
CommonClass CC = new CommonClass();
protected void Page_Load(object sender, EventArgs e)
{
//获取符合条件的新闻信息
this.dlNews.DataSource = CC.GetDataSet(Convert.ToString(Session["search"]), "tbNews");
this.dlNews.DataKeyField = "id";
this.dlNews.DataBind();
//显示查询条件
this.labSC.Text = Convert.ToString(Session["tool"]);
}
protected void dlNews_ItemCommand(object source, DataListCommandEventArgs e)
{
int id = Convert.ToInt32(dlNews.DataKeys[e.Item.ItemIndex].ToString());
Response.Write("<script language=javascript>window.open('showNews.aspx?id=" + id + "','','width=520,height=260')</script>");

}
protected void dlNews_SelectedIndexChanged(object sender, EventArgs e)
{

}
}

在这里面调用的,一个新闻查询页面
KerryMo 2009-04-05
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zhangjie_it 的回复:]
你在哪里调用了这个函数:
public System.Data.DataSet GetDataSet(string sqlStr, string TableName)
{}
[/Quote]
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class search : System.Web.UI.Page
{
CommonClass CC = new CommonClass();
protected void Page_Load(object sender, EventArgs e)
{
//获取符合条件的新闻信息
this.dlNews.DataSource = CC.GetDataSet(Convert.ToString(Session["search"]), "tbNews");
this.dlNews.DataKeyField = "id";
this.dlNews.DataBind();
//显示查询条件
this.labSC.Text = Convert.ToString(Session["tool"]);
}
protected void dlNews_ItemCommand(object source, DataListCommandEventArgs e)
{
int id = Convert.ToInt32(dlNews.DataKeys[e.Item.ItemIndex].ToString());
Response.Write("<script language=javascript>window.open('showNews.aspx?id=" + id + "','','width=520,height=260')</script>");

}
protected void dlNews_SelectedIndexChanged(object sender, EventArgs e)
{

}
}

在这里面调用的,一个新闻查询页面
zhangjie_it 2009-04-05
  • 打赏
  • 举报
回复
并且sqldataadapter中的数据库连接是自动关闭的,不需要手动关闭的!
zhangjie_it 2009-04-05
  • 打赏
  • 举报
回复
你在哪里调用了这个函数:
public System.Data.DataSet GetDataSet(string sqlStr, string TableName)
{}

KerryMo 2009-04-05
  • 打赏
  • 举报
回复
运行后总显示ExecuteReader: CommandText 属性尚未初始化

111,126

社区成员

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

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

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