从SQLite数据库检索数据时出错

时间:2019-02-19 07:39:03

标签: android

我正在尝试在手机上获取SQLite数据库值。数据在数据库中可用,但是此光标类显示的是数据库中不可用的值。我该如何解决这个问题?

这是databasehelper调用函数

String imgname=img_name.getText().toString();
Cursor cursor = db.pname(imgname);

if(cursor.getCount()== 0)
{
    Toast.makeText(getApplicationContext(), "Values are not available", Toast.LENGTH_SHORT).show();
}
else
{
    while (cursor.moveToFirst())
    {
        Toast.makeText(getApplicationContext(), "name"+cursor.getColumnIndex("name"), Toast.LENGTH_SHORT).show();
    }
}
cursor.close();

DatabaseHelpe r类

public Cursor pname(String imgname) {
    String name = imgname.toString();
    String sql = "select * from '"+MSG+"' where product='"+name+"'";
    SQLiteDatabase db = this.getReadableDatabase();
    Cursor cursor = db.rawQuery(sql, null);
    return cursor;
}

我期望我的产品名称。我该如何解决?

1 个答案:

答案 0 :(得分:1)

请勿在单引号中使用MSG。您的查询应为:

select * from tablename where ...

String sql = "select * from "+MSG+" where product='"+name+"'";

tablename不能用单引号引起来。