6

哪一个更好地执行 ms-sql 数据库的插入语句:

Sql DataAdapter 还是 SQL 命令对象?

哪个会更好, whileinserting only one row和 while inserting multiple rows

一个简单的代码使用示例:

SQL 命令

string query = "insert into Table1(col1,col2,col3) values (@value1,@value2,@value3)";
int i;

SqlCommand cmd = new SqlCommand(query, connection);
// add parameters...
cmd.Parameters.Add("@value1",SqlDbType.VarChar).Value=txtBox1.Text;
cmd.Parameters.Add("@value2",SqlDbType.VarChar).Value=txtBox2.Text;
cmd.Parameters.Add("@value3",SqlDbType.VarChar).Value=txtBox3.Text;
cmd.con.open();
i = cmd.ExecuteNonQuery();
cmd.con.close();

SQL 数据适配器

DataRow dr = dsTab.Tables["Table1"].NewRow();
DataSet dsTab = new DataSet("Table1");
SqlDataAdapter adp = new SqlDataAdapter("Select * from Table1", connection);
adp.Fill(dsTab, "Table1");
dr["col1"] = txtBox1.Text;
dr["col2"] = txtBox5.Text;    
dr["col3"] = "text";

dsTab.Tables["Table1"].Rows.Add(dr);

SqlCommandBuilder projectBuilder = new SqlCommandBuilder(adp);
DataSet newSet = dsTab.GetChanges(DataRowState.Added);
adp.Update(newSet, "Table1");
4

3 回答 3

3

使用 DataAdapter 更新数据源要容易得多。由于您只需要修改 DataSet 并调用 Update,因此更容易进行更改。

使用 DataAdapters 与使用命令之间的性能可能没有(或很少)差异。DataAdapter 在内部使用 Connection 和 Command 对象并执行 Command 以执行您告诉它们执行的操作(例如填充和更新),因此它与仅使用 Command 对象几乎相同。

于 2011-07-04T08:42:53.417 回答
2

对于单个插入和大多数数据库 CRUD 请求,我会使用带有 DataSet 的 LinqToSql。它是类型安全的,对于上述非复杂查询来说相对较快。

如果您有很多行要插入 (1000+) 并且您使用的是 SQL Server 2008,我会使用 SqlBulkCopy。您可以使用您的 DataSet 并输入到存储过程中并合并到您的目的地

对于复杂的查询,我建议将dapper与存储过程结合使用。

于 2011-07-04T08:40:01.190 回答
1

我建议您对与数据库的通信进行某种控制。这意味着抽象一些代码,为此 CommandBuilder 会自动为您生成 CUD 语句。

如果您将该技术与类型化的数据集一起使用,那就更好了。然后您对所有列进行智能感知和编译时间检查

于 2011-07-04T08:31:52.083 回答