我正在创建具有DataGrigView以呈现表格的winform应用程序。 我有一个负责与DB一起工作的DAL类。
有一种方法可以加载表的数据:
public static void GetItemsByOrder(int orderId, ref DataSet dataSet)
{
string queryString = @"Select Id,OrderId as [מס' הזמנה],ItemCode as[מק""ט], ItemName as [שם פריט], ReceiptDate as [ת. הספקה],
WarrantyExpDate as [באחריות עד],SuppliersItemCode as [מק""ט ספק], Supplier as [ספק], Count as[כמות], Active
FROM OrdersManager_Items where OrderId = @param";
SqlConnection connection = new SqlConnection(connectionString);
SqlCommand command = new SqlCommand(queryString, connection);
command.Parameters.AddWithValue("@param", orderId);
SqlDataAdapter adapter = new SqlDataAdapter(command);
try
{
lock (myLock)
{
adapter.Fill(dataSet,"Items");
}
}
catch (Exception ex)
{
LogWriter.WriteLogEntry(LogWriter.LogType.ERROR, string.Format("Failed to get Items by OrderId code from DB."+
"This is due to exception: {0},\n StackTrace: {1}. ", ex.Message, ex.StackTrace));
dataSet = null;
}
}
第二种方法负责使用表中所做的更改来更新数据库:
public static bool UpdateItemsByOrder(int orderId, DataSet data)
{
string queryString = @"Select Id,OrderId as [מס' הזמנה],ItemCode as[מק""ט], ItemName as [שם פריט], ReceiptDate as [ת. הספקה],
WarrantyExpDate as [באחריות עד],SuppliersItemCode as [מק""ט ספק], Supplier as [ספק], Count as[כמות], Active
FROM OrdersManager_Items where OrderId = @param";
SqlConnection connection = new SqlConnection(connectionString);
SqlCommand command = new SqlCommand(queryString, connection);
command.Parameters.AddWithValue("@param", orderId);
SqlDataAdapter adapter = new SqlDataAdapter(command);
try
{
lock (myLock)
{
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
int rowsUpdated = adapter.Update(data,"Items");
return true;
}
}
catch (Exception ex)
{
LogWriter.WriteLogEntry(LogWriter.LogType.ERROR, string.Format("Failed to update Items table in DB. This is due to exception: {0},\n StackTrace: {1}. ", ex.Message, ex.StackTrace));
return false;
}
}
问题: 如果在Items表中添加或删除了新行 - UpdateItemsByOrder按预期添加/删除DB中的行。 但是,项目表的现有行中的更新不会在DB中更新。
没有错误或例外。 我尝试添加builder.GetUpdateCommand()命令=无结果。
我很乐意得到任何帮助或建议。感谢
P> S>我正在使用此MSDN LINK来学习如何使用SQLAdapter
答案 0 :(得分:1)
好的,根据sallushan的建议,我得到了解决方案: DataAdapter未更新数据库的原因是DataTable中更新的行具有RowState值“Unchanged”而不是“Modified”。
有两种基本方法可以解决此问题:
感谢所有人的帮助: - )
答案 1 :(得分:0)
您是否意识到您运行SELECT命令而不是更新权限?
我的猜测是adapter.Update
只是选择,然后报告没有更新的行,因为没有。