c# - 过程或函数需要未提供的参数。执行非查询

标签 c# asp.net sql-server visual-studio-2010 tsql

所以问题如下:

当我单击注册 Web 表单上的提交按钮时(在文本框中添加相应的值之后),“oCom.ExecuteNonQuery();”行出现错误。它说

"Procedure or function 'ADDUSR' expects parameter '@useremail', which was not supplied."

我一直试图找出它为什么这么说,因为我仔细检查了 oUsr.Email = "hello@hello.com",该信息来自调试器,这是有道理的,因为我只是在单击提交按钮之前将其添加到文本框中。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Data;

namespace Carnisoftix
{
    public partial class Register : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
        }

        protected void btnSubmit_Click(object sender, EventArgs e)
        {
            carniuser oUsr = new carniuser();

            oUsr.Email = txtEmail.Text;
            oUsr.Name = txtName.Text;
            oUsr.Pass = txtPassword.Text;
            oUsr.Phone = txtPhone.Text;
            oUsr.Usrname = txtUsername.Text;
            oUsr.Address = txtAddress.Text;
            oUsr.SpecialK = Convert.ToInt16(txtSpecial.Text);
            oUsr.Auth = 1;
            regUsr(oUsr);

        }
        public static void regUsr(carniuser oUsr)
        {
            //int oNum;
            SqlConnection oConnection = new SqlConnection("Server=.\\SQLExpress;AttachDbFilename=L:\\Apps\\VS Projects\\Carnisoftix\\CarniDb.mdf;Database=CarniDb;Trusted_Connection=Yes;");
            string oSql = "ADDUSR";
            SqlCommand oCom = new SqlCommand(oSql, oConnection);
            oCom.CommandType = CommandType.StoredProcedure;
            oCom.Parameters.AddWithValue("@useremail ,", oUsr.Email);
            oCom.Parameters.AddWithValue("@userpass, ", oUsr.Pass);
            oCom.Parameters.AddWithValue("@name, ", oUsr.Name);
            oCom.Parameters.AddWithValue("@phone, ", oUsr.Phone);
            oCom.Parameters.AddWithValue("@address, ", oUsr.Address);
            oCom.Parameters.AddWithValue("@username, ", oUsr.Usrname);
            oCom.Parameters.AddWithValue("@authority, ", oUsr.Auth);
            oCom.Parameters.AddWithValue("@special, ", oUsr.SpecialK);
            //SqlParameter oReturn = new SqlParameter("@out", SqlDbType.Int);
            //oReturn.Direction = ParameterDirection.ReturnValue;
            //oCom.Parameters.Add(oReturn);
            oConnection.Open();
            oCom.ExecuteNonQuery();
            //oNum = (int)oCom.Parameters["@out"].Value;
            oConnection.Close();
            //return oNum;
        }
    }
    /* my database's stored procedure requires this parameters:
    @useremail,
    @username,
    @userpass,
    @name,
    @phone,
    @address,
    @authority,
    @special*/
    public class carniuser
    {
        private string email, usrname, pass, name, phone, address;
        private int authority, specialK;
        public carniuser()
        {
            email = "";
            usrname = "";
            pass = "";
            name = "";
            phone = "";
            address = "";
            authority = 1;
            specialK = 1;
        }
        public string Email
        {
            get { return email; }
            set { email = value; }
        }
        public string Pass
        {
            get { return pass; }
            set { pass = value; }
        }
        public string Name
        {
            get { return name; }
            set { name = value; }
        }
        public string Phone
        {
            get { return phone; }
            set { phone = value; }
        }
        public string Address
        {
            get { return address; }
            set { address = value; }
        }
        public string Usrname
        {
            get { return usrname; }
            set { usrname = value; }
        }
        public int Auth
        {
            get { return authority; }
            set { authority = value; }
        }
        public int SpecialK
        {
            get { return specialK; }
            set { specialK = value; }
        }

        public carniuser(string email, string usrname, string pass, string name, string phone, string address, int authority, int specialK)
        {
            Email = email;
            Usrname = usrname;
            Pass = pass;
            Name = name;
            Phone = phone;
            Address = address;
            Auth = authority;
            SpecialK = specialK;
        }
    }
}

这里有我正在尝试使用的数据库存储过程:

CREATE PROCEDURE ADDUSR

@useremail varchar (35),
@username varchar (30),
@userpass varchar (30),
@name varchar (100),
@phone varchar (20),
@address varchar (150),
@authority int,
@special bit

AS
BEGIN
INSERT INTO USERS
(
_UserEmail,
_UserName,
_UserPass ,
_Name ,
_Phone,
_Address,
_Authority,
_Special
)
VALUES
(
@useremail,
@username,
@userpass,
@name,
@phone,
@address,
@authority,
@special
)
END

最佳答案

你只是在编写usermail参数时犯了一个错误。

改变

oCom.Parameters.AddWithValue("@useremail ,", oUsr.Email);

oCom.Parameters.AddWithValue("@useremail", oUsr.Email);

并删除 AddWithValue 方法中的所有逗号。喜欢;

oCom.CommandType = CommandType.StoredProcedure;
oCom.Parameters.AddWithValue("@useremail", oUsr.Email);
oCom.Parameters.AddWithValue("@userpass", oUsr.Pass);
oCom.Parameters.AddWithValue("@name", oUsr.Name);
oCom.Parameters.AddWithValue("@phone", oUsr.Phone);
oCom.Parameters.AddWithValue("@address", oUsr.Address);
oCom.Parameters.AddWithValue("@username", oUsr.Usrname);
oCom.Parameters.AddWithValue("@authority", oUsr.Auth);
oCom.Parameters.AddWithValue("@special", oUsr.SpecialK);

关于c# - 过程或函数需要未提供的参数。执行非查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16276434/

相关文章:

c# - 如何在mysql连接中正确地将 'localhost'替换为你自己的公共(public)IP

c# - 从列表中返回单个对象

c# - 使用 RNGCryptoServiceProvider 生成随机字符串

c# - 从 ListView 模型更新服务中的多个表行?

python - 对 SQL 结果进行排序以提高可读性?

jquery - 使用jquery和webmethod在Gridview中延迟加载

asp.net - 回发或回调参数无效。调试问题

asp.net session 安全

sql - 如何将日期显示为 mm/dd/yyyy hh :mm Am/PM using sql server 2008 r2?

SQL 包含 - 仅在开始时匹配