我有一个在Customers类别的Northwind数据库中执行插入,更新和删除操作的任务。我设法做了插入部分,并认为这一切都完成了,因为代码应该是相似的,但是......我写了基本上复制插入的Update,只是更改了对存储过程的引用,但是当我按下按钮时,没有发生。代码:
private void buttonUpdate_Click(object sender, RoutedEventArgs e)
{
SqlConnection cn = new SqlConnection(@"Integrated Security=SSPI;Initial Catalog=Northwind;Data Source=(local)");
SqlCommand cmd = new SqlCommand("UpdateCustomer", cn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@CustomerID", "");
cmd.Parameters.AddWithValue("@CompanyName", companyName);
cmd.Parameters.AddWithValue("@ContactName", contactName);
cmd.Parameters.AddWithValue("@ContactTitle", contactTitle);
cmd.Parameters.AddWithValue("@Address", address);
cmd.Parameters.AddWithValue("@City", city);
cmd.Parameters.AddWithValue("@PostalCode", zip);
cmd.Parameters.AddWithValue("@Phone", phone);
cmd.Parameters.AddWithValue("@Region", "");
cmd.Parameters.AddWithValue("@Country", "");
cmd.Parameters.AddWithValue("@Fax", "");
cn.Open();
cmd.ExecuteNonQuery();
cn.Close();
}
我的存储过程来自MSDN:
CREATE PROCEDURE [dbo].[UpdateCustomer]
@CustomerID nchar(5),
@CompanyName nvarchar(40),
@ContactName nvarchar(30),
@ContactTitle nvarchar(30),
@Address nvarchar(60),
@City nvarchar(15),
@Region nvarchar(15),
@PostalCode nvarchar(10),
@Country nvarchar(15),
@Phone nvarchar(24),
@Fax nvarchar(24)
AS
UPDATE [dbo].[Customers]
SET [CompanyName] = @CompanyName
,[ContactName] = @ContactName
,[ContactTitle] = @ContactTitle
,[Address] = @Address
,[City] = @City
,[Region] = @Region
,[PostalCode] = @PostalCode
,[Country] = @Country
,[Phone] = @Phone
,[Fax] = @Fax
WHERE CustomerID=@CustomerID
但没有任何改变。我究竟做错了什么? 另外,我是否需要使用级联来删除客户,因为这些表是合并的。
这是一个基本项目,我不知道任何DataSet和东西,所以在搜索了1000个网站后,我仍然无法想出这个... :(任何帮助将不胜感激!
答案 0 :(得分:1)
要执行特定客户的UPDATE
,您需要传递CustomerID
:
cmd.Parameters.AddWithValue("@CustomerID", ""); <- Don't pass an empty string here..
[不是问题的原因,但我会调查为什么您将CustomerID
列定义为nchar(5)
]