使用 DataAdapter 将 DataTable 插入数据库不起作用
我正在尝试使用 DataAdapter 将 DataTable 插入数据库表(数据库位于移动设备 - Psion 上)。由于某种原因,它不起作用 - 当我检查数据库表时 - 它只是显示为空表......
代码: >
private void btnCommTables_Click(对象发送者,EventArgs e)
{
尝试
{
数据集 ds = WSDanielGroup.Instance._WSDanielGroupToDevice.GetLoadTables();
DataTable DT = ds.Tables["Peer"];
string SelectCMD = "INSERT INTO Peer(ID,PeerID) Values(?,?)";
SqlCeConnection cn = new SqlCeConnection(DBManager.sLocalConnectionString);
SqlCeDataAdapter da=new SqlCeDataAdapter();
da.InsertCommand = new SqlCeCommand(SelectCMD, cn);
cn.Open();
da.InsertCommand.Parameters.Add("@ID", SqlDbType.Int,4,"ID");
da.InsertCommand.Parameters.Add("@PeerID", SqlDbType.NVarChar,50, "PeerID");
int numRows = da.Update(DT);
}
I am trying to insert DataTable into a DB table (the DB is on a mobile device - Psion), using a DataAdapter. from some reason, it does not work - when i check the DB table - it simply appears as an empty table...
the code:
>
private void btnCommTables_Click(object sender, EventArgs e)
{
try
{
DataSet ds = WSDanielGroup.Instance._WSDanielGroupToDevice.GetLoadTables();
DataTable DT = ds.Tables["Peer"];
string SelectCMD = "INSERT INTO Peer(ID,PeerID) Values(?,?)";
SqlCeConnection cn = new SqlCeConnection(DBManager.sLocalConnectionString);
SqlCeDataAdapter da=new SqlCeDataAdapter();
da.InsertCommand = new SqlCeCommand(SelectCMD, cn);
cn.Open();
da.InsertCommand.Parameters.Add("@ID", SqlDbType.Int,4,"ID");
da.InsertCommand.Parameters.Add("@PeerID", SqlDbType.NVarChar,50, "PeerID");
int numRows = da.Update(DT);
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
一种可能的解释是您的 DataTable 没有正确的 RowVersions。 DataAdapter 将仅更新表中已更改的行。如果您从其他地方获取它,它会认为一切正常并且不需要更新任何内容(未标记为“脏”的行)。更多信息请参见此处。
One possible explanation is that your DataTable doesn't have the correct RowVersions. The DataAdapter will only update rows that have been changed in the table. If you get it from somewhere else, it thinks everything's OK and nothing needs to be updated (rows not marked "dirty"). More info here.