C# 如何解决asp.net中ExecuteOnQuery()中的错误
错误: System.Data.dll中发生“System.Data.SqlClient.SqlException”类型的异常,但未在用户代码中处理 其他信息:提供的值的列名或数量与表定义不匹配 代码:C# 如何解决asp.net中ExecuteOnQuery()中的错误,c#,asp.net,sql-server,ado.net,C#,Asp.net,Sql Server,Ado.net,错误: System.Data.dll中发生“System.Data.SqlClient.SqlException”类型的异常,但未在用户代码中处理 其他信息:提供的值的列名或数量与表定义不匹配 代码: 明确提及列名,如下所示;假设列名为n和p。另外,使用重载Add()方法,而不是AddWithValue() 检查firsttb表中的列数。它应该与通过ado.net代码传递的许多值相匹配 例如,如果第一个TB表有三列,则在Insert Into语句中传递三个值 此外,请检查要传递的值的顺序。因为
明确提及列名,如下所示;假设列名为
n
和p
。另外,使用重载Add()
方法,而不是AddWithValue()
// Identity Column
CREATE TABLE Persons
(
ID int IDENTITY(1,1) PRIMARY KEY,
Username varchar(255) NOT NULL,
Password varchar(255) NOT NULL
);
使用
插入值时
必须为所有列提供数据。或者,如果插入到特定的表列中,则需要说明要插入数据的列<代码>插入(columnName1、columnName2等)值(value1、value2等)id也在那里,但主键和我只有两个文本框,一个是名称,另一个是密码,所以我应该怎么做?id也在那里,但主键和我只有两个文本框,一个是名称和另一个密码,所以我应该怎么做id只是主键还是标识列?如果您的主键列不是标识列,那么您必须也传递它的值。。在totalin表单中表示三个值,即名称和密码,而在数据库中,其中三个值是在表单中定义的,您还需要传递三个值。如果您没有id,那么每次在dbid中插入记录时都必须创建新id,但主键和我只有两个文本框,一个用于名称,另一个用于密码,那么我该怎么办?
cmd.CommandText="INSERT INTO firsttb(n, p) VALUES ( @n , @p )";
// Identity Column
CREATE TABLE Persons
(
ID int IDENTITY(1,1) PRIMARY KEY,
Username varchar(255) NOT NULL,
Password varchar(255) NOT NULL
);