我的数据库中有一个表有三列:Screen,Icon和Rank:我试图找到最简洁的方法来实现以下功能.
我想找到所有行WHERE Screen =“myScreen”和Rank> 5 //然后使得排名第一小于当前值..我在Java中通过sqlite Manager类在以下函数中执行此操作:
public void DeleteScreenIcon (int id, String screenName, int rank){
int screenID = getScreenID(screenName);
sqliteDatabase db=this.getWritableDatabase();
db.delete(isLookUp, colScreenID + "=" + screenID + " and " +colIconID+ "="+id, null);
// HERE IS WHERE I Now WANT TO DO THAT..
db.execsql("update "+ isLookUp +" set "+colRank+ "=" +colRank+ " -1 "+" where " + colScreenID + "='" +screenName + "' and " + colRank +">" +rank);
db.close();
}
对不起,我不熟悉sql任何帮助表示赞赏
解决方法:
此更新应该可以解决问题:
UPDATE myTable
SET Rank = Rank - 1
WHERE Screen = "myScreen"
AND Rank > 5;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。