C# 如何使用c sql server向现有表中添加新行
我需要写一个程序。程序的一部分是写入sql数据库.mdf。 我在尝试向表中添加一个名为:Data的新行时遇到了很多麻烦。代码如下:C# 如何使用c sql server向现有表中添加新行,c#,sql,database,C#,Sql,Database,我需要写一个程序。程序的一部分是写入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); ... S
...
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");
...
我执行了这段代码,但是数据没有保存到表中。有人知道如何在表中输入新行并保存它吗?您的SqlDataAdapter中需要一个
编辑:
这里有一个快速的例子。还有很多其他的,但这应该让你走。它假设您有一个表dbo.Foos,其中有两列Foo int,Bar nvarchar50
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();
}
}
}
我看到的两件事是,您无论如何都不会初始化数据集ds或SqlDataAdapter da,除非您只是将其保留在简化后。da初始化的一部分将给它一个实际的sql命令。尝试设置
dRow = new DataRow();
而不是
dRow = ds.Tables["Data"].NewRow();
改变
da.Update(ds, "Data");
到
强制数据集接受更改,即添加ds.Acceptchanges到您的代码他会初始化它:string sql=SELECT*From Data;da=新System.Data.SqlClient.SqlDataAdaptersql,con;他只需要一个InsertCommand,就可以使da-1 DataRow类具有一个内部构造函数。你不能在桌子外创建一个谢谢你的回答。你能给我写一个例子吗,因为我尝试使用“InsertCommand”,但我失败了。再次感谢!
da.Update(ds);