java - 如何在 ListView 中仅显示一列数据?
问题描述
我有一个包含信息的数据库,当我请求数据时,我只想在我的 中显示一列ListView
,以便用户可以选择他们想要显示的信息
这是我的数据库助手:
public Cursor viewData () {
SQLiteDatabase db = this.getReadableDatabase();
Cursor res = db.rawQuery("Select * from " +TABLE_NAME, null);
return res;
}
我的代码:
private void viewData() {
Cursor cursor = db.viewData();
if (cursor.getCount()== 0){
Toast.makeText(this,"No Data To Show", Toast.LENGTH_LONG).show();
}else {
while(cursor.moveToNext()){
listItems.add(cursor.getString(0));//index 1 is name, 0 is ID
}
String[] StringArray = new String[]{
DatabaseHelper.COL_2
};
int[] IntArray = new int[]{
R.id.textView1
};
adapter = new SimpleCursorAdapter(this, R.layout.item_layout, cursor, StringArray, IntArray);
userList.setAdapter(adapter);
}
}
我的 item_layout.xml 文件:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/mway">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="8dp"
android:textColor="@color/colorPrimary"
android:textSize="28sp"
android:textStyle="bold"/>
</RelativeLayout>
解决方案
将布局的高度更改为:
android:layout_height="wrap_content"
所以它将是:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/mway">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="8dp"
android:textColor="@color/colorPrimary"
android:textSize="28sp"
android:textStyle="bold"/>
</RelativeLayout>
推荐阅读
- python - Cypher & Neo4j : 带有 Cypher 请求的 for 循环
- ansible - 迭代ansible中的字典列表时,有什么方法可以删除特定的键值?
- ios - 自定义 UIView 在 View Controller 中被解包为 nil
- python - 如何在 Parrot OS 中安装 Anbox?
- nginx - nginx tcp 转发到多个 IP
- mysql - MySQL:将值插入 json 对象
- python - Python cv2.imshow 无法在 vscode 中在线运行
- laravel - 在laravel 7中注册后重定向到上一页
- android - 如何在我的 Android Webview 中启用全屏视频播放
- snowflake-cloud-data-platform - 在 Snowflake 中克隆的表可以成为源吗?