![](/img/trans.png)
[英]How can I get the row id of the a table in the sqlite database when an Item is clicked in the listview
[英]How do I read certain data from sqlite database and show it in a dialog when a listview item is clicked?
這顯示了我的listview onclick偵聽器,當我單擊一個項目時,我想打開一個對話框以顯示sqlite信息。單擊listview項時如何獲取日期和注釋。 以下是我的嘗試,但不起作用。 我也是android編程的新手,所以如果您可以在代碼中解決問題,那對我非常有幫助。
ListAdapter adapter = new ArrayAdapter<>(getActivity(), android.R.layout.simple_list_item_1, listData);
mListView.setAdapter(adapter);
//set an onItemClickListener to the ListView
mListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
String name = adapterView.getItemAtPosition(i).toString();
Log.d(TAG, "onItemClick: You Clicked on " + name);
Cursor data = mDatabaseHelper.getexpenseItemID(name); //get the id associated with that name
int itemID = -1;
while(data.moveToNext()){
itemID = data.getInt(0);
}
if(itemID > -1){
displayNoteDate(mDatabaseHelper.getexpenseNote(data2),mDatabaseHelper.getexpenseDate(data1));
}
else{
toastMessage("No ID associated with that name");
}
}
});
public void displayNoteDate(String noteContent, String dateValue) {
final Dialog builder = new Dialog(getActivity());
builder.setContentView(R.layout.custom_dialog);
builder.setTitle("Display note date");
TextView note = (TextView)builder.findViewById(R.id.note);
TextView date = (TextView)builder.findViewById(R.id.date);
//add the database note and date
note.setText(noteContent);
date.setText(dateValue);
Button closeButton = (Button)builder.findViewById(R.id.close);
closeButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
builder.dismiss();
}
});
builder.show();
}
DatabaseHelper.java
public class DatabaseHelper extends SQLiteOpenHelper {
private static final String TAG = "DatabaseHelper";
public static final String DATABASE_NAME = "budget.db";
public static final String TABLE_NAME = "expense_table";
public static final String TABLE_NAME2 = "income_table";
public static final String COL_1 = "ID";
public static final String COL_2 = "ID2";
public static final String EXPENSE_AMOUNT = "AMOUNT";
public static final String EXPENSE_DATE = "DATE";
public static final String EXPENSE_NOTES = "NOTES";
public static final String INCOME_AMOUNT = "AMOUNT";
public static final String INCOME_DATE = "DATE";
public static final String INCOME_NOTES = "NOTES";
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, 3);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table " + TABLE_NAME + " (ID INTEGER PRIMARY KEY AUTOINCREMENT,AMOUNT INTEGER,DATE INTEGER,NOTES TEXT)");
db.execSQL("create table " + TABLE_NAME2 + " (ID INTEGER PRIMARY KEY AUTOINCREMENT,AMOUNT INTEGER,DATE INTEGER,NOTES TEXT)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME2);
onCreate(db);
}
public boolean insertexpenseData(String amount_expense, String date_expense, String notes_expense) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put(EXPENSE_AMOUNT, amount_expense);
contentValues.put(EXPENSE_DATE, date_expense);
contentValues.put(EXPENSE_NOTES, notes_expense);
long result = db.insert(TABLE_NAME, null, contentValues);
if (result == -1)
return false;
else
return true;
}
public boolean insertincomeData(String amount_income, String date_income, String notes_income) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put(INCOME_AMOUNT, amount_income);
contentValues.put(INCOME_DATE, date_income);
contentValues.put(INCOME_NOTES, notes_income);
long result = db.insert(TABLE_NAME2, null, contentValues);
if (result == -1)
return false;
else
return true;
}
public Cursor getexpenseData() {
SQLiteDatabase db = this.getWritableDatabase();
Cursor res = db.rawQuery("select * from " + TABLE_NAME, null);
return res;
}
public Cursor getincomeData() {
SQLiteDatabase db = this.getWritableDatabase();
Cursor res = db.rawQuery("select * from " + TABLE_NAME2, null);
return res;
}
public Cursor getexpenseDate(Cursor date){
SQLiteDatabase db = this.getWritableDatabase();
String query = "SELECT * FROM " + TABLE_NAME + " WHERE " + EXPENSE_DATE + " = '" + date + "'";
Cursor data1 = db.rawQuery(query, null);
return data1;
}
public Cursor getexpenseNote(Cursor note){
SQLiteDatabase db = this.getWritableDatabase();
String query = "SELECT * FROM " + TABLE_NAME + " WHERE " + EXPENSE_NOTES + " = '" + note + "'";
Cursor data2 = db.rawQuery(query, null);
return data2;
}
public Cursor getexpenseItemID(String name){
SQLiteDatabase db = this.getWritableDatabase();
String query = "SELECT " + COL_1 + " FROM " + TABLE_NAME + " WHERE " + EXPENSE_AMOUNT + " = '" + name + "'";
Cursor data = db.rawQuery(query, null);
return data;
}
public Cursor getincomeItemID(String name){
SQLiteDatabase db = this.getWritableDatabase();
String query = "SELECT " + COL_2 + " FROM " + TABLE_NAME2 + " WHERE " + INCOME_AMOUNT + " = '" + name + "'";
Cursor data = db.rawQuery(query, null);
return data;
}
public boolean updateexpenseData(String id, String amount, String date, String notes) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put(COL_1, id);
contentValues.put(EXPENSE_AMOUNT, amount);
contentValues.put(EXPENSE_DATE, date);
contentValues.put(EXPENSE_NOTES, notes);
db.update(TABLE_NAME, contentValues, "ID = ?", new String[]{id});
return true;
}
public boolean updateincomeData(String id, String amount, String date, String notes) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put(COL_2, id);
contentValues.put(INCOME_AMOUNT, amount);
contentValues.put(INCOME_DATE, date);
contentValues.put(INCOME_NOTES, notes);
db.update(TABLE_NAME2, contentValues, "ID = ?", new String[]{id});
return true;
}
public Integer deleteexpenseData(String id) {
SQLiteDatabase db = this.getWritableDatabase();
return db.delete(TABLE_NAME, "ID = ?", new String[]{id});
}
public Integer deleteincomeData(String id) {
SQLiteDatabase db = this.getWritableDatabase();
return db.delete(TABLE_NAME2, "ID = ?", new String[]{id});
}
}
使用這個方法
Cursor cursor = mDatabaseHelper.getexpenseItemID(name);
if (cursor.getCount() > 0){
cursor.moveToFirst();
String noteContent = cursor.getString(cursor.getColumnIndex("NOTES"));
String date = cursor.getString(cursor.getColumnIndex("DATE"));
Toast.makeText(Activity.this, noteContent, Toast.LENGTH_SHORT).show();
Toast.makeText(Activity.this, date, Toast.LENGTH_SHORT).show();
displayNoteDate(noteContent, date);
}
只要吐司回顯了您的數據,就知道您已成功從數據庫中讀取數據。
這是一個解決方案(假設displayNoteDate
可以工作,並且已經通過Toast進行了測試),該解決方案使用CursorAdapter而不是ListAdapter 。
好處是雙重的,不需要創建中間數組,並且您在onItemClickListener
擁有所有可用數據。
但是,一個陷阱是Cursor adpater希望使用名為_id的列,因此我將幫助器中的onCreate
方法更改為:-
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table " + TABLE_NAME + " (_id INTEGER PRIMARY KEY AUTOINCREMENT,AMOUNT INTEGER,DATE INTEGER,NOTES TEXT)");
db.execSQL("create table " + TABLE_NAME2 + " (_id INTEGER PRIMARY KEY AUTOINCREMENT,AMOUNT INTEGER,DATE INTEGER,NOTES TEXT)");
}
即_id替換ID
為了進行測試,我添加了以下內容以添加一些數據:
mDatabaseHelper.insertexpenseData("100.00","21/03/1904","Wow this old?");
mDatabaseHelper.insertexpenseData("56.78","31/12/2010","New Celebrations");
mDatabaseHelper.insertexpenseData("250.00","23/08/2017","Birthday Present");
我使用的實際代碼(除了第一行以外的其他數據將其作為游標獲取)與您的代碼緊密相關( onItemClick
的主體( onItemClick
從游標獲取數據)除外)是:
.......
expensedata = mDatabaseHelper.getexpenseData();
SimpleCursorAdapter sca = new SimpleCursorAdapter(this,
android.R.layout.simple_list_item_1,
expensedata,
new String[]{DatabaseHelper.EXPENSE_AMOUNT},
new int[]{android.R.id.text1}, 0);
listdata.setAdapter(sca);
listdata.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
int csrpos = expensedata.getPosition();
expensedata.moveToPosition(i);
displayNoteDate(
expensedata.getString(expensedata.getColumnIndex(DatabaseHelper.EXPENSE_NOTES)),
expensedata.getString(expensedata.getColumnIndex(DatabaseHelper.EXPENSE_DATE)));
expensedata.moveToPosition(csrpos);
}
});
}
//!!!NOTE!!! Used for testing so don't use this method.
private void displayNoteDate(String notes, String date) {
Toast.makeText(this,"Notes=" + notes + " Incurred on " + date,Toast.LENGTH_LONG).show();
}
@Override
public void onDestroy() {
super.onDestroy();
expensedata.close();
}
注意expensedata
被宣布為使用類變量Cursor expensedata;
請注意,完成操作后應關閉光標。 我使用了一個活動,因此為此使用了onDestroy
方法。
運行時顯示:-
當單擊56.78 (對於其他列表項也是如此)時:-
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.