java - 我正在尝试在 android 的 sql lite 数据库中更新播放器的分数,但它没有发生
问题描述
这是 DBHelper 类中的更新函数,它在每个正确答案后将分数更新 10。我的插入功能工作正常,但是当更新功能触发应用程序正在更改其活动并且分数没有得到更新时
public Boolean updateScore(String username,Integer score)
{
SQLiteDatabase db = this.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put("username", username);
contentValues.put("score", score);
long result = db.update( "scores",contentValues, username + " = ?", new String[]
{username});
if (result==-1) return false;
else return true;
}
这是我在检查按钮后面的编码。它检查单词是否正确,然后分数增加 10。插入功能工作正常。
check.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
player.start();
if (answer.getText().toString().isEmpty()){
Toast.makeText(easy_level.this,"Enter you guess first",
Toast.LENGTH_SHORT).show();
}
else if (answer.getText().toString().equalsIgnoreCase(pet)){
Toast.makeText(easy_level.this,"You are correct", Toast.LENGTH_SHORT).show();
answer.setText("");
pet = pets[random.nextInt(pets.length)];
question.setText(mixWords(pet));
count.start();
//insertingScore
if(score_int == 0){
Boolean insert = DB.insertScore(name,10);
score_int +=10;
score.setText(String.valueOf(score_int));
if (insert==true)
{
Toast.makeText(easy_level.this,"added 10",Toast.LENGTH_SHORT).show();
}else
{
Toast.makeText(easy_level.this,"failed",Toast.LENGTH_SHORT).show();
}
}else {
score_int +=10;
score.setText(String.valueOf(score_int));
Boolean update = DB.updateScore(name,score_int);
if (update==true)
{
Toast.makeText(easy_level.this,"updated
10",Toast.LENGTH_SHORT).show();
}else
{
Toast.makeText(easy_level.this,"update
fail",Toast.LENGTH_SHORT).show();
}
}
}else {
Toast.makeText(easy_level.this,"You are wrong", Toast.LENGTH_SHORT).show();
}
}
});
解决方案
在您db.update()
中,您引用的是值而不是列名
long result = db.update( "scores",contentValues, username + " = ?", new String[]
{username});
应该
long result = db.update( "scores",contentValues, "username = ?", new String[]
{username});
推荐阅读
- css - 样式化为页面的当前目标部分(“some_url#section”)提供链接的锚标记
- git - 从 tfs repo 迁移到 gitlab 社区版
- python - 检查pickle文件的pickle协议
- html - 如何在画布下方有表格
- r - 各种观察的子集
- java - 如何在java中将int转换为日期?
- orm - Symfony 4:调用 getter 后,Doctrine2 LAZY Fetch Collection 仍然为空
- javascript - 如何在 Vue Material 的 md-dialog 上捕获属性更新?
- amazon-web-services - 过滤 Dynamo DB 行
- php - Informix 数据库 Laravel 7