2

我想创建一个新的 DbCommand,但得到一些错误:

DbCommand insertcommand = new DbCommand("insert into persons(firstname, lastname, email) values(?, ?, ?)", connection);
insertcommand.Parameters.Add(1, DbType.String, 50, "fistname");
insertcommand.Parameters.Add(2, DbType.String, 50, "lastname");
insertcommand.Parameters.Add(3, DbType.String, 100, "email");
dbAdapter.InsertCommand = insertcommand;

这会产生错误

无法创建抽象类或接口“System.Data.Common.DbCommand”的实例

方法“添加”没有重载需要 4 个参数

我应该如何创建这些命令并填充参数?

4

2 回答 2

5

您通常需要直接创建一个具体实例(new SqlCommand等)或使用IDbConnection.CreateCommand.

目前尚不清楚哪个最适合您的情况。

至于Add调用 - 如果您使用具体的命令类型,您可能会有更多的重载可供您使用。否则,您可能需要使用IDbCommand.CreateParameter、设置属性,然后将其添加到参数集合中。

于 2012-05-01T16:36:33.107 回答
0

您需要创建一个新的 SQLParameter 并向其中添加所有内容。然后,将 SQLParameter 作为参数传递。我相信,Parameters.Add 只接受一个参数,那就是你的 SQLParameter。

http://msdn.microsoft.com/en-us/library/yy6y35y8(v=vs.80).aspx

于 2012-05-01T16:37:25.743 回答