ListView: 是Android中的一个视图组件,用于显示垂直滚动的可变长度的数据列表。它通过适配器(Adapter)来获取数据并显示每一项。
SQLite数据库: 是一个轻量级的嵌入式数据库,广泛用于Android应用中存储结构化数据。
ArrayList: 是Java中的一个动态数组实现,可以方便地添加、删除和查找元素。
以下是一个简单的示例,展示如何在Android Studio中使用ListView显示SQLite数据库中的数据。
public class DatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "mydatabase.db";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "mytable";
private static final String COLUMN_ID = "id";
private static final String COLUMN_NAME = "name";
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
String createTableQuery = "CREATE TABLE " + TABLE_NAME + " (" +
COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
COLUMN_NAME + " TEXT)";
db.execSQL(createTableQuery);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
onCreate(db);
}
}
public class MyAdapter extends BaseAdapter {
private Context context;
private ArrayList<String> dataList;
public MyAdapter(Context context, ArrayList<String> dataList) {
this.context = context;
this.dataList = dataList;
}
@Override
public int getCount() {
return dataList.size();
}
@Override
public Object getItem(int position) {
return dataList.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = LayoutInflater.from(context).inflate(android.R.layout.simple_list_item_1, parent, false);
}
TextView textView = convertView.findViewById(android.R.id.text1);
textView.setText(dataList.get(position));
return convertView;
}
}
public class MainActivity extends AppCompatActivity {
private ListView listView;
private ArrayList<String> dataList;
private DatabaseHelper dbHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = findViewById(R.id.listView);
dbHelper = new DatabaseHelper(this);
dataList = new ArrayList<>();
// 假设已经从数据库中获取了数据并填充到dataList中
Cursor cursor = dbHelper.getReadableDatabase().query("mytable", new String[]{"name"}, null, null, null, null, null);
if (cursor.moveToFirst()) {
do {
dataList.add(cursor.getString(0));
} while (cursor.moveToNext());
}
cursor.close();
MyAdapter adapter = new MyAdapter(this, dataList);
listView.setAdapter(adapter);
}
}
原因: 可能是由于每次滚动时都重新创建视图或频繁调用findViewById导致的。
解决方法: 使用ViewHolder模式缓存视图组件,减少不必要的查找操作。
static class ViewHolder {
TextView textView;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = LayoutInflater.from(context).inflate(android.R.layout.simple_list_item_1, parent, false);
holder = new ViewHolder();
holder.textView = convertView.findViewById(android.R.id.text1);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.textView.setText(dataList.get(position));
return convertView;
}
原因: 可能是由于适配器没有通知ListView数据已经改变。
解决方法: 在更新数据后调用适配器的notifyDataSetChanged方法。
dataList.add("New Item");
adapter.notifyDataSetChanged();
通过以上步骤,你可以有效地在Android应用中使用ListView显示SQLite数据库中的数据,并解决常见的性能和刷新问题。
领取专属 10元无门槛券
手把手带您无忧上云