2012-03-23 4 views
2

私のデータベースには、スクリーン、アイコン、ランクの3つのテーブルがあります。以下を実現する最もクリーンな方法を探しています。私はSQLiteテーブルのintカラムを減らすことができます

は、私は次の関数でのSQLite Managerクラスを経由して、Javaでこれをやっている...画面=「マイスクリーン」とランク> 5は、//その後、ランク現在の値よりも小さいものを作るすべての行を見つけたいです

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(); 
    } 

申し訳ありませんが、イムそれは、任意のヘルプは、この更新笙

+0

SQLでは、更新ステートメントで 'Rank = Rank-1'を実行するだけです。 – Sjoerd

+0

私は同様の問題があります: - 'ContentValues dataToInsert = new ContentValues(); dataToInsert.put(MARKER_ID、MARKER_ID + " - 1"); 文字列where = IMAGE_ID_F + "=" + imageId + "AND" + MARKER_ID + ">" + markerId + ";"; int resultUpdate = db.update(TABLE_DEFECTS、dataToInsert、where、null); ' –

+0

上記は機能していないようです。 –

答えて

5

を高く評価しているSQLに精通していません

UPDATE myTable 
SET Rank = Rank - 1 
WHERE Screen = "myScreen" 
AND Rank > 5; 
+0

あなたはそのようなセットを使うことができるかどうか確かめてくれてありがとう。 – erik

+0

あなたのレスポンスを反映させるために、上記のコード行を私のメソッドに追加しました。これをjavaで正しく書式設定しているのでしょうか? – erik

+0

私はそれをありがとう一束!! – erik

関連する問題