android - 获取选定的 ListView 项的 ID(使用 SQLite 数据库填充的数据)

标签 android database sqlite listview

我有一个数据库,用于跟踪用户的提醒数据(提醒名称、备注、日期、时间等)。第一列是它的主键 (_ID)。 ListView 是从数据库中填充的,它显示了一组带有提醒名称的简单行,如下所示:


倒垃圾。


遛狗。


吃午饭。


等等


现在我的问题是,如何让我的应用程序确定点击了哪个特定提醒?单击一行时,我需要从我的数据库中找到它的主键(_ID 列)并能够检索该行中的所有数据。

到目前为止,我知道我需要使用 onItemClick 来检测点击。但是如何获取被点击的item的主键值(_ID)呢?我当前的代码如下所示:

final Context context = this;

//DB Connectivity variables.
protected RemindersDAO remindersDAO;
protected SimpleCursorAdapter remindersCursorAdapter;
public ListView viewRemindersListView;

@SuppressWarnings("deprecation")
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_view_local_reminders);

    // Get rid of the app title in the action bar.
    ActionBar actionBar = getSupportActionBar();
    actionBar.setDisplayShowTitleEnabled(false);

    viewRemindersListView = (ListView) findViewById(R.id.listview_view_local_reminders);

    remindersDAO = new RemindersDAO(this);
    Cursor cursor = remindersDAO.all(this);

    remindersCursorAdapter = new SimpleCursorAdapter(this,
                                     R.xml.view_reminders_item_layout,
                                     cursor, new String [] { RemindersDAO.NAME },
                                     new int[] { R.id.view_reminders_item_text } );

    viewRemindersListView.setAdapter(remindersCursorAdapter);
}

@Override
public void onItemClick(AdapterView<?> listView, View view, int position, long arg3) {
    remindersDAO = new RemindersDAO(this);
    Cursor cursor = remindersDAO.all(this);

    int idColIndex = cursor.getColumnIndex(RemindersDAO._ID); 
    int rowId = cursor.getInt(idColIndex); 
}

@Override
public boolean onCreateOptionsMenu(com.actionbarsherlock.view.Menu menu) {
    // TODO Auto-generated method stub
    MenuInflater inflater = getSupportMenuInflater();
    inflater.inflate(R.menu.activity_view_local_reminders, menu);

    return super.onCreateOptionsMenu(menu);
}

public boolean onOptionsItemSelected(MenuItem item) {
     //Set the classes that are called from each actionbar item.
     switch (item.getItemId()) {
         case R.id.local_reminders_actionbar_go_advanced:
             Intent i=new Intent(this, AdvancedNewReminder.class);
             startActivity(i);
             return true;
         case R.id.local_reminders_actionbar_simple_reminder:
             Intent k = new Intent(this, QuickNewReminder.class);
             startActivity(k);
             return true;

             /* case R.id.local_reminders_actionbar_google_tasks:
             showGoogleTasksBetaDialog();
             return true; */

     }
     return false;
 }

@Override
public void onBackPressed() {
    return;
}

感谢您的帮助!

最佳答案

onItemClick 方法中,您可以看到第三个参数-long id 是数据库中的id。所以你只需简单地获取点击的项目 ID

  @Override
    public void onItemClick(AdapterView<?> listView, View view, int position, long arg3) {
       Log.d("Clicked item id", " "+ arg3); 
    }

如果你想要其他字段,你应该得到点击项目的光标

   @Override
    public void onItemClick(AdapterView<?> listView, View view, int position, long arg3) {
     Cursor item=   (Cursor) reminderCursorAdapter.getItem(position);
Log.d("Clicked item field", " "+ item.getColum(your colum index)); 
    }

关于android - 获取选定的 ListView 项的 ID(使用 SQLite 数据库填充的数据),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12486835/

相关文章:

python - 如何在 python 对象中存储 SQL 数据库,并在对象中执行查询?

java - 数据库管理中的问题 - sqlite with Java (IDE : NetBeans)

c# - Sqlite 数据库被锁定

插入新行时 Android Room FOREIGN KEY 约束失败(代码 787)

android studio 2.0 预览模拟器不显示新按钮

android - 移动设备特定 CSS 不工作

Android 在单击按钮时从 url 加载图像

android - Eclipse 未检测到我的 Sony Xperia Z1 Compact

android - 连接到 MySQL 数据库

sql - 在 rank() over 之后只选择 3 个排名最好的