我是android新手。我想要显示从数据库插入的数据到一个表。我用List来获取数据。不能完全从数据库中清除数据的列表
public List<user> getAllUsers() {
List<user> users = new ArrayList<user>();
Cursor cursor = database.query(SqlLiteHelper.TABLE_USER, allColumns, null, null, null, null, null);
cursor.moveToFirst();
while (!cursor.isAfterLast()) {
user varUser = cursorToUser(cursor);
//Log.v("user name",varUser.getName().toString());
users.add(varUser);
cursor.moveToNext();
}
//Log.v("user name",users.get(0).getName().toString());
cursor.close();
return users;
}
private user cursorToUser(Cursor cursor) {
user varUser = new user();
//Log.v("user id", cursor.getString(1).toString());
varUser.setID(cursor.getLong(0));
varUser.setName(cursor.getString(1));
varUser.setPhone(cursor.getString(2));
varUser.setEmail(cursor.getString(3));
return varUser;
}
我写了一篇关于UserDataSource.java
此代码然后,我需要显示这些我用下面的代码
databaseSource = new UserDataSource(this);
databaseSource.open();
List<user> values = databaseSource.getAllUsers();
Log.v("information", values.get(0).getName().toString());
ArrayAdapter<user> adapter = new ArrayAdapter<user>(this, android.R.layout.simple_list_item_1, values);
setListAdapter(adapter);
在列表中这不是增加值的数据。我使用log.v来检查数据是否回来。我发现数据来自数据库。只有当我尝试打印列表或将其插入到simple_list_item_1时,它才会解决问题。
在打印
的击打其假设从数据库打印的名称。
数据库表名是用户。
请让我知道我缺少什么。
这里就是我试图添加这些列表
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<Button
android:id="@+id/all_user_back"
style="?android:attr/buttonStyleSmall"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="10dp"
android:text="Back" />
<ListView
android:id="@android:id/list"
android:layout_width="match_parent"
android:layout_height="384dp" >
</ListView>
</LinearLayout>
这是什么cursorToUser(光标);方法呢? – 2013-02-20 08:19:21
函数corsorToUser(光标游标)用于使用检索数据创建用户类的对象。我将对象列表保存为LIST – 2013-02-20 08:21:02
我们需要查看您的用户类和cursorToUser()方法。唯一我能想到的是,你以某种方式将错误的列映射到getName()..请更新 – Entreco 2013-02-20 08:24:08