gpt4 book ai didi

java - Android 使用线程执行 SQLite 查询

转载 作者:行者123 更新时间:2023-12-01 18:11:55 25 4
gpt4 key购买 nike

我正在尝试为一个应用程序创建一个餐馆及其项目的数据库,作为熟悉 android 的入门项目。我有一个来自先前 Activity 的列表,其中用户单击餐厅名称并显示项目。我创建了一个 helperDB 类来处理插入语句和数据库设置,尽管当我从新线程内部调用插入方法时,它们似乎没有执行。我提供了以下代码:

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_display_bar);

getSupportActionBar().setDisplayHomeAsUpEnabled(true);

Intent intent = getIntent();
String barName = intent.getStringExtra(MainActivity.EXTRA_MESSAGE);
final TextView tv = (TextView) findViewById(R.id.name);
tv.setText(barName);

restaurants = new ArrayList<String>();
mydb = new DBHelper(this);

new Thread(new Runnable() {
@Override
public void run() {
mydb.insertDrink("cake", "McD's", 8);
mydb.insertDrink("muffin", "The Woods", 8);
restaurants = mydb.getDrinks("The Woods");
System.out.println(restaurants);
}
}).start();


ArrayAdapter arrayAdapter=new ArrayAdapter(this,android.R.layout.simple_list_item_1, restaurants);

obj = (ListView)findViewById(R.id.listview);
obj.setAdapter(arrayAdapter);
}

insert语句和getDrinks方法的代码如下:

public boolean insertDrink(String drink, String name, int price){
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();

contentValues.put("drink", drink);
contentValues.put("name", name);
contentValues.put("price", price);
db.insert("Bars", null, contentValues);
return true;
}
public ArrayList<String> getDrinks(String name){
ArrayList<String> arrayList = new ArrayList<>();

SQLiteDatabase db = this.getReadableDatabase();
Cursor res = db.rawQuery("select * from Bars", null);
res.moveToFirst();

while(res.isAfterLast() == false){
arrayList.add(res.getString(res.getColumnIndex(BAR_COLUMN_DRINK)));
res.moveToNext();
}
return arrayList;
}

我知道我不应该从 UI 线程之外的任何线程访问任何 Android 工具包,尽管我不认为我正在这样做。如果这不是填充 SQLite android 数据库的正常方法,我当然也愿意学习在哪里执行此操作。

最佳答案

although when I called my insert method from inside a new thread, they do not seem to execute.

你怎么能这么说呢?您是否看到数据库中的数据条目?或者仅查找restaurant ArrayList

我怀疑您没有获得 Restaurant ArrayList,因为您的线程异步运行。

线程执行后的下一条语句无需等待填充恢复数组列表。

解决方案:

使用AsyncTaskdoInBackground() 中调用数据库内容,并在 onPostExecute() 中获取结果,并在同一方法中设置带有结果的适配器。

关于java - Android 使用线程执行 SQLite 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32340453/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com