出错信息:未将对象引用设置到对象的实例。 
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.NullReferenceException: 未将对象引用设置到对象的实例。源错误: 
行 61:  SqlCommand myCommand = new SqlCommand(str,myConnection);
行 62:  myCommand.Parameters.Add(new SqlParameter("@ans",SqlDbType.NVarChar,2000));
行 63:             myCommand.Parameters["@ans"].Value = answer.Text;
行 64:  myCommand.Parameters.Add(new SqlParameter("@da",SqlDbType.NChar,50));
行 65:  myCommand.Parameters["@da"].Value = DateTime.Now;
 源文件: c:\inetpub\wwwroot\web\answermessage.aspx.cs    行: 63

解决方案 »

  1.   

    代码没能错误,要不就是你所设置的字段不允许空。
    是执行了NULL操作!!
      

  2.   

    我上面的代码只是更新messagelist表中的两个字段的值。这两个字段允许空。请帮忙。十分感谢!
      

  3.   

    改成下面代码试试:
    SqlCommand myCommand = new SqlCommand(str,myConnection);
     myCommand.Parameters.Add("@ans",SqlDbType.NVarChar,2000);
    myCommand.Parameters[0].Value = answer.Text;
     myCommand.Parameters.Add("@da",SqlDbType.NChar,50);
     myCommand.Parameters[1].Value = DateTime.Now;
      

  4.   

    chyich() 你好!
    还是不行。
      

  5.   

    完整的代码如下:using System;
    using System.Collections;
    using System.ComponentModel;
    using System.Data;
    using System.Data.SqlClient;
    using System.Drawing;
    using System.Web;
    using System.Web.SessionState;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;namespace Web
    {
    /// <summary>
    /// answermessage 的摘要说明。
    /// </summary>
    public class answermessage : System.Web.UI.Page
    {
    protected System.Web.UI.WebControls.TextBox answer;
    protected System.Web.UI.WebControls.RequiredFieldValidator Rfv_content;
    protected System.Web.UI.WebControls.DataList DataList2;
    public int key;
    protected System.Web.UI.HtmlControls.HtmlForm Form1;

    SqlConnection myConnection = new SqlConnection("server=(local);database=web;uid=sa;pwd=;");

    private void Page_Load(object sender, System.EventArgs e)
    {
    if (Session["adminuser"] == null)
    {
                    Response.Write("<script language=javascript>window.location.href='adminlogin.aspx'</script>");
    Response.End();
    } key = int.Parse((Request.QueryString["name"])); if (!IsPostBack)
    {
    ListBind();
    }
    }
    private void ListBind()
    {
               string strSel="select * from messagelist where id='"+key+"'";

    SqlDataAdapter MyAdapter = new SqlDataAdapter(strSel,myConnection);
               
    DataSet ds = new DataSet();
                MyAdapter.Fill(ds,"messagelist"); DataList2.DataSource=ds.Tables["messagelist"].DefaultView;
    DataList2.DataBind();
    }
    public void Answer_Click(Object sender, EventArgs E)
    {
    string str="update messagelist set answer=@ans,adate=@da where id='"+key+"'";
    SqlCommand myCommand = new SqlCommand(str,myConnection);
    myCommand.Parameters.Add(new SqlParameter("@ans",SqlDbType.NVarChar,1000));
                myCommand.Parameters["@ans"].Value = answer.Text;
    myCommand.Parameters.Add(new SqlParameter("@da",SqlDbType.NChar,50));
    myCommand.Parameters["@da"].Value = DateTime.Now; myCommand.Connection.Open(); myCommand.ExecuteNonQuery();
    Response.Write("<script language=javascript>alert('回复留言成功!!!')</script>");
    Response.End();
    myCommand.Connection.Close();
    }
    #region Web 窗体设计器生成的代码
    override protected void OnInit(EventArgs e)
    {
    //
    // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
    //
    InitializeComponent();
    base.OnInit(e);
    }

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

  6.   

    建议你把数据库字段都允许空,输入判断放在程序里,用RequiredFieldValidator!-----------努力学习 不断实践 虚心讨教---------