过程或函数需要未提供的参数.ExecuteNonQuery

本文关键字:参数 ExecuteNonQuery 函数 过程 | 更新日期: 2023-09-27 18:11:14

问题如下:

当我点击提交按钮在我的注册web表单(在文本框中添加相应的值后)有一个错误的行"oCom.ExecuteNonQuery();"。上面写着

"过程或函数'ADDUSR'期望参数'@useremail',其中没有提供。"

我一直在试图找出为什么它说,因为我仔细检查了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

过程或函数需要未提供的参数.ExecuteNonQuery

您刚才写错了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);
oCom.Parameters.AddWithValue("@useremail ,", oUsr.Email);
                                       ^^^^

试试这个-

static string connectionString = "Server=.''SQLExpress;AttachDbFilename=L:''Apps''VS Projects''Carnisoftix''CarniDb.mdf;Database=CarniDb;Trusted_Connection=Yes;";
public static void regUsr(carniuser oUsr)
{
    using(SqlConnection oConnection = new SqlConnection(connectionString))
    {
        oConnection.Open();
        using (SqlCommand oCom = new SqlCommand("ADDUSR", 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);
            oCom.ExecuteNonQuery();
        }
        oConnection.Close();
    }
}