我正在开发一个从 SQLite 数据库中获取数据的应用程序。我有表格中的数据。当我在模拟器中运行应用程序时,它正在正确获取数据。但是当我尝试在设备中调试时,没有获取任何数据。游标返回 0 行。它在模拟器中工作正常。
我有一个触发数据库调用并返回数组列表的按钮单击事件,代码片段如下所示:
f4.setOnClickListener(new OnClickListener()
{
@SuppressWarnings("deprecation")
@SuppressLint("NewApi")
@Override
public void onClick(View v) {
if (Build.VERSION.SDK_INT >= 16) {
f4.setBackground(getResources().getDrawable(
R.drawable.standards_btn_pressed));
} else {
f4.setBackgroundDrawable(getResources()
.getDrawable(R.drawable.standards_btn_pressed));
}
List<ProductModel> pList = new ArrayList<ProductModel>();
db = new DataBaseHelper(getApplicationContext());
pList = db.getData("F4");
showTextFields(pList);
}
});
//getData function
public List<ProductModel> getData(String param) {
SQLiteDatabase db = this.getWritableDatabase();
String[] queryParam = new String[] { param.trim() };
Cursor cursor=null;
try
{
cursor = db.rawQuery(
"select * from FEPAFMACRO WHERE gritsize = ?", queryParam);
}
catch (Exception e) {
e.printStackTrace();
}
List<ProductModel> pList = new ArrayList<ProductModel>();
if (cursor.getCount() != 0) {
if (cursor.moveToFirst()) {
int i = 0;
do {
ProductModel pObj = new ProductModel();
pObj.gritSize = cursor.getString(cursor
.getColumnIndex("gritsize"));
.getColumnIndex("retention"));
pList.add(i, pObj);
i++;
} while (cursor.moveToNext());
}
}
return pList;
}
当我在模拟器中运行它时,它会显示数据。但是当我在设备中运行时,不会获取任何数据。也没有错误。日志报告中也没有任何内容