如何使用C# SQL Server向现有表中添加新行

6

我需要编写一个程序。其中的一部分是要写入到 SQL 数据库 (.mdf) 中。 我在尝试向表格中添加新行 (名为:"Data") 时遇到了很多麻烦。以下是代码:

...
DataSet ds = new DataSet();
System.Data.SqlClient.SqlDataAdapter da;
DataRow dRow;
string sql = "SELECT * From Data";
da = new System.Data.SqlClient.SqlDataAdapter(sql, con);
...
System.Data.SqlClient.SqlCommandBuilder cb;
cb = new System.Data.SqlClient.SqlCommandBuilder(da);
dRow = ds.Tables["Data"].NewRow();
dRow[0] = "my_data1";
dRow[1] = "my_data2";
dRow[2] = "my_data3";
...
ds.Tables["Data"].Rows.Add(dRow);
da.Update(ds, "Data");
...

我执行了这段代码,但是数据没有保存到表格中。有人知道如何输入新行到表格并保存吗?

4个回答

8

你的SqlDataAdapter需要一个InsertCommand

编辑:

这里是我草拟的一个快速示例。虽然还有很多其他示例,但这应该能让你开始。它假定你有一个表(dbo.Foos),其中有两列(Foo int, Bar nvarchar(50))。

namespace DataAdapterSample
{
    using System;
    using System.Data;
    using System.Data.SqlClient;

    class Program
    {
        static void Main(string[] args)
        {
            using (SqlConnection connection = new SqlConnection(@"Data Source=[your server];Initial Catalog=[your database];Integrated Security=true;"))
            {
                using (SqlDataAdapter dataAdapter = new SqlDataAdapter())
                {
                    dataAdapter.SelectCommand = new SqlCommand("select Foo, Bar from dbo.Foos", connection);
                    dataAdapter.InsertCommand = new SqlCommand("insert into dbo.Foos (Foo, Bar) values (@Foo, @Bar)", connection);
                    dataAdapter.InsertCommand.Parameters.Add(new SqlParameter("Foo", SqlDbType.Int, 4, "Foo"));
                    dataAdapter.InsertCommand.Parameters.Add(new SqlParameter("Bar", SqlDbType.NText, 50, "Bar"));

                    using (DataSet dataSet = new DataSet())
                    {
                        dataAdapter.Fill(dataSet);

                        Console.WriteLine("There are {0} rows in the table", dataSet.Tables[0].Rows.Count);

                        DataRow newRow = dataSet.Tables[0].NewRow();
                        newRow["Foo"] = 5;
                        newRow["Bar"] = "Hello World!";
                        dataSet.Tables[0].Rows.Add(newRow);

                        dataAdapter.Update(dataSet);
                    }                

                    //Just to prove we inserted
                    using (DataSet newDataSet = new DataSet())
                    {
                        dataAdapter.Fill(newDataSet);
                        Console.WriteLine("There are {0} rows in the table", newDataSet.Tables[0].Rows.Count);                
                    }                
                }
            }
            Console.ReadLine();        
        }
    }
}

感谢您的回答。您能否给我写一个示例,因为我尝试使用“InsertCommand”,但是我失败了。再次感谢! - menachem

1

强制数据集接受更改,即在您的代码中添加ds.Acceptchanges


0

我看到的两个问题是,你没有以任何方式初始化你的数据集(ds)或SqlDataAdapter(da)(除非你仅仅是因为后续简化而省略了)。DataAdapter的初始化的一部分将是给它一个实际的SQL命令。


他只需要在da上添加一个InsertCommand: string sql = "SELECT * From Data"; da = new System.Data.SqlClient.SqlDataAdapter(sql, con); - Adrian Zanescu

-1

尝试设置

dRow = new DataRow();

而不是

dRow = ds.Tables["Data"].NewRow();

并且改变

da.Update(ds, "Data");

da.Update(ds);

1
-1 DataRow类有一个内部构造函数。你不能在表外创建它。 - Adrian Zanescu

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接