ExecuteNonQuery() 不执行~,

zhwedo0822 2009-05-18 10:07:48

protected void next_Click(object sender, EventArgs e)
{
MySqlConnection mysqlcon = new MySqlConnection("Server=localhost;userid=root;password=1234;Database=zhwedo");

mysqlcon.Open();
MySqlCommand mysqlcmd = new MySqlCommand("select * from sdb_members where uname='"+this.username.Text+"'", mysqlcon);

if (mysqlcmd.ExecuteNonQuery() == 1)
{
MySqlDataReader dr;
dr = mysqlcmd.ExecuteReader();
Session["uname"] = dr["uname"].ToString();
mysqlcon.Close();
Response.Redirect("xuanze.aspx");


}
else
{
Response.Write("<script language=\"javascript\" type=\"text/javascript\">function ale(){alert(\"输入的用户名与Email验正不正确,重新输入\");}</script>");
this.username.Text = "";
this.email.Text = "";
mysqlcon.Close();


}
}

...全文
157 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
zuoming120 2009-05-18
  • 打赏
  • 举报
回复
首先我说我的理解啊,ExecuteNonQuery()是在数据库所增加,修改,删除的时候用。而你的sql语句是查询啊,怎么能用呢?你把几个对象多看看书,以下是我修改后的代码,你看看,希望对你有帮助,


protected void next_Click(object sender, EventArgs e)
{
MySqlConnection mysqlcon = new MySqlConnection("Server=localhost;userid=root;password=1234;Database=zhwedo");


MySqlCommand mysqlcmd = new MySqlCommand("select * from sdb_members where uname='"+this.username.Text+"'", mysqlcon);
mysqlcon.Open();
MySqlDataReader dr=mysqlcmd.ExecuteReader();;
if (dr.Read())
{
Session["uname"] = dr["uname"].ToString();
Response.Redirect("xuanze.aspx");
}
else
{
Response.Write("<script language=\"javascript\" type=\"text/javascript\">function ale(){alert(\"输入的用户名与Email验正不正确,重新输入\");}</script>");
this.username.Text = "";
this.email.Text = "";


}
mysqlcon.Close();
}
zhwedo0822 2009-05-18
  • 打赏
  • 举报
回复
好的,我这就按大家的方法去试!
困困困扰 2009-05-18
  • 打赏
  • 举报
回复
ExecuteNonQuery()只有Insert,Update,Delete的时候才会有返回,Select对数据是没有影响的,
你应该调用Execute(sql),然后去Table中取值!
zhwedo0822 2009-05-18
  • 打赏
  • 举报
回复
大侠们,小第是个彻底的小鸟,能给个正确的写法吗!谢谢了!
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 zgke 的回复:]
不知道你的 MySqlCommand 类是怎么写的

但SqlCommand的ExecuteNonQuery方法 对Select查询结果返回为-1
[/Quote]

ExecuteNonQuery方法执行的时候返回的是受影响的行数,select 不会返回受影响的行数.结果始终是-1
你直接 SqlDataReader dr=mysqlcmd.ExectureReader();//返回一个数据阅读器
if(dr.Read())
{
Session["uname"] = dr["uname"].ToString();
mysqlcon.Close();
Response.Redirect("xuanze.aspx");

}
zhwedo0822 2009-05-18
  • 打赏
  • 举报
回复
mysql的方法是从网上下载的MySql.Data.dll
来客心动 2009-05-18
  • 打赏
  • 举报
回复
你这代码,问题还不止这里啊

dr = mysqlcmd.ExecuteReader();
Session["uname"] = dr["uname"].ToString();

有这样写的吗,汗,dr得到的是指针,你要dr.Reader()才可以dr["uname"]哦
BernardSun 2009-05-18
  • 打赏
  • 举报
回复
不用套这层
直接 MySqlDataReader dr;
dr = mysqlcmd.ExecuteReader();
然后判断dr就行了
zgke 2009-05-18
  • 打赏
  • 举报
回复
不知道你的 MySqlCommand 类是怎么写的

但SqlCommand的ExecuteNonQuery方法 对Select查询结果返回为-1
来客心动 2009-05-18
  • 打赏
  • 举报
回复
你这里mysqlcmd.ExecuteNonQuery执行的结果是0,所以不执行咯
zhwedo0822 2009-05-18
  • 打赏
  • 举报
回复
if (mysqlcmd.ExecuteNonQuery() == 1)
就是数据库里有这个也不执行!为什么呀?
本文介绍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编程的良好示例,例如添加数据时界面并没有很好地更新。

62,046

社区成员

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

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

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

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