java – 如何减少SQLite表的int列

我的数据库中有一个表有三列: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;

相关文章

SQLite架构简单,又有Json计算能力,有时会承担Json文件/RES...
使用Python操作内置数据库SQLite以及MySQL数据库。
破解微信数据库密码,用python导出微信聊天记录
(Unity)SQLite 是一个软件库,实现了自给自足的、无服务器...
安卓开发,利用SQLite实现登陆注册功能