[英]getting and adding data to existing SQLite database
我試圖從一個表中獲取數據,然后將其添加到另一個表中。 我需要從表1自動遞增的KEY_CATEGORYID
,然后將其添加到表2和4。我無法弄清楚該怎么做,因為KEY_CATEGORYID
僅在createBudget
方法完成后才有一個值,並且在addId
之后addId
發生說完了,這讓我完全不明白該怎么做,我們將不勝感激。
public SQLiteDatabase createBudget(String bname, String bpay, String bamount,
String bmemo) {
// TODO Auto-generated method stub
ContentValues t1 = new ContentValues();
ContentValues t2 = new ContentValues();
ContentValues t4 = new ContentValues();
t1.put(KEY_NAME, bname);
t1.put(KEY_PAYDAY,bpay);
t2.put(KEY_AMOUNT, bamount);
t2.put(KEY_DATE, date);
t4.put(KEY_MEMO, bmemo);
t4.put(KEY_DATE,date);
ourDatabase.insert(DATABASE_TABLE1, null, t1);
ourDatabase.insert(DATABASE_TABLE2, null, t2);
ourDatabase.insert(DATABASE_TABLE4, null, t4);
addID(bname);
return ourDatabase;
}
private void addID(String bname) throws SQLException {
// TODO Auto-generated method stub
ContentValues num = new ContentValues();
List<String> nums = new ArrayList<String>();
int number = 0;
String[] columns = new String[]{KEY_CATEGORYID};
Cursor c = ourDatabase.query(DATABASE_TABLE1, columns,KEY_CATEGORYID + "=?", new String[] {String.valueOf(bname)}, null, null, null, null);
if(c!= null)
{
if (c.moveToFirst()) {
nums.add(c.getString(0));
number = nums.get(0);
}
num.put(KEY_CATEGORYID, number);
}
ourDatabase.insert(DATABASE_TABLE2, null, num);
ourDatabase.insert(DATABASE_TABLE4, null, num);
}
insert
方法返回自動生成的鍵值:
long key = ourDB.insert(TABLE1, null, t1);
t2.put(KEY_CATEGORYID, key);
ourDB.insert(TABLE2, null, t2);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.