我在 windows mobile v6 上将 sqlite 用于我的 .NET Compact Framework 3.5 应用程序。如果我插入大数据,我将面临速度缓慢的问题。
考虑一下这种情况:我的ArrayList
(比如说List1
)中有大约 150 件物品。我有一个包含两列(比如itemid
和isFound
)的数据库表。
我必须迭代每个元素List1
并在我的数据库中检查 itemid 是否可用
- 如果 itemid 在表中可用,则将 isFound 状态更新为 1 。
- 如果 itemid 不可用,则插入并更新 isFound 状态。
为此,大约需要 30 秒,最快的方法是什么?
这是我当前的代码:
public ArrayList InsertNewlyScannedItems(ref ArrayList newlyScannedItemList)
{
ArrayList newInsertedItemList = new ArrayList();
SQLiteConnection conn = new SQLiteConnection("Data Source=" + db + ";Version=3;");
SQLiteDataReader rs = null;
try
{
conn.Open();
SQLiteCommand availableTable = conn.CreateCommand();
IEnumerator en = newlyScannedItemList.GetEnumerator();
while (en.MoveNext())
{
ItemInfo itmInfo = (ItemInfo)en.Current;
string cmdText = "";
cmdText = "Select id, isFound item where id = '" + itmInfo.id + "'";
availableTable.CommandText = cmdText;
rs = availableTable.ExecuteReader();
if (rs.Read())
{
if (!itmInfo.id.Equals(""))
{
availableTable.Dispose();
availableTable.CommandText = "UPDATE item SET isFound = @isFound Where id = @id";
availableTable.Parameters.AddWithValue("@isFound", itmInfo.isFound);
availableTable.Parameters.AddWithValue("@id", itmInfo.id);
availableTable.ExecuteNonQuery();
}
}
else
{
availableTable.Dispose();
cmdText = "INSERT INTO item(id, isFound)";
cmdText += "VALUES ( '" + itmInfo.id + "','" + itmInfo.isFound + ")";
availableTable.CommandText = cmdText;
availableTable.ExecuteNonQuery();
}
newInsertedItemList.Add(itmInfo);
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
if (rs != null)
{
//rs.Close();
//rs.Dispose();
}
if (conn != null && conn.State == ConnectionState.Open)
{
conn.Close();
conn = null;
}
}
return newInsertedItemList;
}