我想插入现有应用程序数据表的应用程序的类别.我不知道我是否正确,但在我正在做的事情我也得到了这个错误.
我该怎么做才能正确?
主要活动
AlertDialog.Builder builder = new AlertDialog.Builder(
MainActivity.this);
builder.setTitle("Please Select Category of : " + AppName);
builder.setItems(shareItems,
new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int item) {
// TODO Auto-generated method stub
String itemz = String.valueOf(shareItems[item]);
mySQLiteAdapter.insertcategory(AppName, itemz);
}
});
AlertDialog shareAlert = builder.create();
shareAlert.show();
Run Code Online (Sandbox Code Playgroud)
处理器
public long insertcategory(String AppName, String itemz) {
// TODO Auto-generated method stub
Cursor crack = sqlitedb.rawQuery("INSERT INTO " + KEY_CATEGORY
+ " VALUES ( ' " + itemz + " ' ) WHERE " + KEY_NAME
+ " LIKE ?", new String[] { "%" + AppName+ "%" });
return 0;
}
Run Code Online (Sandbox Code Playgroud)
更新的查询 这是我用来更新表的内容.itemz将值作为"游戏"获取,但它没有得到更新
public long insertcategory(String AppName, String itemz) {
// TODO Auto-generated method stub
ContentValues values = new ContentValues();
values.put(KEY_CATEGORY, itemz);
return sqlitedb.update(MYDATABASE_TABLE, values, KEY_NAME + " LIKE ?",
new String[] { "%" + AppName + "%" });
}
Run Code Online (Sandbox Code Playgroud)
表创建为
private static final String SCRIPT_CREATE_DATABASE = "create table "
+ MYDATABASE_TABLE + " (" + KEY_ID
+ " integer primary key autoincrement, " + KEY_NAME
+ " text not null, " + KEY_PACK + " text not null, " + KEY_PERM
+ " text not null, " + KEY_LEVEL + " text not null, "
+ KEY_CATEGORY + " text);";
Run Code Online (Sandbox Code Playgroud)
INSERT命令没有WHERE子句,因为它插入了一个全新的记录.
您似乎想要设置/更改现有记录中的值.这将通过UPDATE命令完成:
UPDATE MyTable SET category = 'Entertainment' WHERE name LIKE ?
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4618 次 |
| 最近记录: |