| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4635 人关注过本帖
标题:第 1 行: '=' 附近有语法错误
只看楼主 加入收藏
enabbv
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-4-21
收藏
 问题点数:0 回复次数:8 
第 1 行: '=' 附近有语法错误

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
using System.Configuration ;
namespace BMS.guestbook
{
/// <summary>
/// reply 的摘要说明。
/// </summary>
public class reply : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label lblSubject;
protected System.Web.UI.WebControls.HyperLink hlkAuthor;
protected System.Web.UI.WebControls.Label lblCount;
protected System.Web.UI.WebControls.Label lblTime;
protected System.Web.UI.WebControls.DataList DataList1;
protected System.Web.UI.WebControls.Label lblMsg1;
protected System.Web.UI.WebControls.Button btnReset;
protected System.Web.UI.WebControls.Button btnReply;
protected System.Web.UI.WebControls.TextBox txtContent;


protected SqlConnection conn=new SqlConnection();
protected System.Web.UI.WebControls.Label Label1;//声明成员conn
private string postID;
private void Page_Load(object sender, System.EventArgs e)
{
if(Session.Count==0)//访问者没有登录
Response.Redirect("../default.aspx");
else//访问者已经登录
{
if(!IsPostBack)
{

postID=Request["PostID"];

}
string strconn= ConfigurationSettings.AppSettings["dsn"];
conn.ConnectionString=strconn;
BindData();


}
}
private void BindData()
{

//留言者的留言情况
string selCmd1 = "select * from GuestBook where PostID="+postID;
SqlDataAdapter da1=new SqlDataAdapter(selCmd1,conn);
//留言的所有回复者回复情况
string selCmd2="select * from GuestBook where ParentID="+postID;
SqlDataAdapter da2=new SqlDataAdapter(selCmd2,conn);
DataSet ds=new DataSet();
da1.Fill(ds,"host");
da2.Fill(ds,"guest");
//留言的主题
lblSubject.Text=ds.Tables["host"].Rows[0][4].ToString();
//留言的回复次数
int reCount=ds.Tables["guest"].Rows.Count;
lblCount.Text=reCount.ToString();
//留言的发表时间
lblTime.Text=ds.Tables["host"].Rows[0][2].ToString();
//留言内容
lblMsg1.Text=ds.Tables["host"].Rows[0][5].ToString();
//留言的作者,并将作者的UID作为参数传到message.aspx
hlkAuthor.Text=ds.Tables["host"].Rows[0][3].ToString();
hlkAuthor.NavigateUrl="message.aspx?UID="+hlkAuthor.Text;
//绑定数据
DataList1.DataSource=ds;
DataList1.DataMember="guest";
DataList1.DataBind();
conn.Close();
}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.btnReset.Click += new System.EventHandler(this.btnReset_Click);
this.btnReply.Click += new System.EventHandler(this.btnReply_Click);
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion

private void btnReply_Click(object sender, System.EventArgs e)
{
string strconn= ConfigurationSettings.AppSettings["dsn"];
conn.ConnectionString=strconn;
string Name=Session["UID"].ToString();
string insCmd="insert GuestBook values("+postID+",getdate(),'"+Name+"',' ','"+txtContent+"')";
SqlCommand cmd=new SqlCommand(insCmd,conn);
cmd.Connection.Open();
cmd.ExecuteNonQuery();
cmd.Connection.Close();
conn.Close();
BindData();
txtContent.Text="";
}

private void btnReset_Click(object sender, System.EventArgs e)
{
txtContent.Text="";
}
}
}
运行出现

第 1 行: '=' 附近有语法错误。

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.Data.SqlClient.SqlException: 第 1 行: '=' 附近有语法错误。

源错误:

行 61: 			SqlDataAdapter da2=new SqlDataAdapter(selCmd2,conn);
行 62: 			DataSet ds=new DataSet();
行 63: 			da1.Fill(ds,"host");
行 64: 			da2.Fill(ds,"guest");
行 65: 			//留言的主题

搜索更多相关主题的帖子: using System 语法 Web 附近 
2006-04-21 10:56
guobinxian
Rank: 1
等 级:新手上路
威 望:2
帖 子:195
专家分:0
注 册:2006-3-28
收藏
得分:0 
private void BindData()
{

//留言者的留言情况
string selCmd1 = "select * from GuestBook where PostID="+postID;
SqlDataAdapter da1=new SqlDataAdapter(selCmd1,conn);

应该是这个的问题吧.获取不到值
前面这样定义private static string postID;
或者是private void BindData(string postID)

?蔾錵輐落溶溶钥,柳絮筂鎕淡淡風?。
2006-04-21 11:30
enabbv
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-4-21
收藏
得分:0 

谢谢,上面的问题已经解决了,还有一个问题,还是上面的代码,就是运行结果无法正确显示回复的内容,
显示以下的状态:

回复者: f 2006-4-21 14:16:14
System.Web.UI.WebControls.TextBox

2006-04-21 14:24
nic
Rank: 2
等 级:新手上路
威 望:4
帖 子:175
专家分:0
注 册:2005-11-1
收藏
得分:0 
SQL语句的问题,改一下这个PostID='"+postID+"'"很多人都有忽视这个问

2006-04-21 14:30
guobinxian
Rank: 1
等 级:新手上路
威 望:2
帖 子:195
专家分:0
注 册:2006-3-28
收藏
得分:0 

我看你上面的代码应该不会出现这样的问题.
你这句话应该是在读取DataList上的值出来的吧.
应该多加个Controls

楼上的朋友.
其实没你说的那个其实要看是什么情况
如果PostID在数据库中是INT型那么就不用加''
而且如果只有一个参数
string selCmd1 = "select * from GuestBook where PostID="+postID;
像这样是没错的.
反之就是你说的那样.
string selCmd1 = "select * from GuestBook where PostID='"+postID+"'";


?蔾錵輐落溶溶钥,柳絮筂鎕淡淡風?。
2006-04-21 14:48
enabbv
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-4-21
收藏
得分:0 
我有在DataList上的显示回复内容的lable控件的text属性里加上了以下的语句,不过还是出现上面的错误
<%# DataBinder.Eval(Container,"DataItem.Content") %>

[此贴子已经被作者于2006-4-21 15:06:56编辑过]

2006-04-21 15:06
enabbv
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-4-21
收藏
得分:0 

问题已解决,只要将 string insCmd="insert GuestBook values("+postID+",getdate(),'"+Name+"',' ','"+txtContent+"')";
改成string insCmd="insert GuestBook values("+postID+",getdate(),'"+Name+"',' ','"+txtContent.Text+"')";

2006-04-21 15:26
guobinxian
Rank: 1
等 级:新手上路
威 望:2
帖 子:195
专家分:0
注 册:2006-3-28
收藏
得分:0 
昏...
原来你是传了个对象进去...

?蔾錵輐落溶溶钥,柳絮筂鎕淡淡風?。
2006-04-21 15:28
enabbv
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-4-21
收藏
得分:0 

谢谢各位

2006-04-21 15:37
快速回复:第 1 行: '=' 附近有语法错误
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.012675 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved