私のqusを落としてください。私はアンドロイドのnubeです。 私はWebサービスを呼び出す1つのアプリケーションを開発しています。結果と私はアンドロイドのSQLデータベースに格納したい。 1つのレコードが保存されていることを示していますが、そのレコードを取得しようとしたときに値が表示されませんでした。私はそれで何がうまくいかないのか理解できません。アンドロイドデータベースのアップデートが正しく動作しない
public class LyricsStore {
private static LyricsStore sInstance = null;
private MusicDB mMusicDatabase = null;
public LyricsStore(final Context context) {
mMusicDatabase = MusicDB.getInstance(context);
}
public static final synchronized LyricsStore getInstance(final Context context) {
if (sInstance == null) {
sInstance = new LyricsStore(context.getApplicationContext());
}
return sInstance;
}
public void onCreate(final SQLiteDatabase db) {
db.execSQL("CREATE TABLE IF NOT EXISTS " + LyricsColumns.NAME + " ("
+ LyricsColumns.ID + " LONG NOT NULL,"
+ LyricsColumns.Lyrics + " STRING NOT NULL);");
}
public void onUpgrade(final SQLiteDatabase db, final int oldVersion, final int newVersion) {
}
public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + LyricsColumns.NAME);
onCreate(db);
}
int result = 0;
public boolean AddUpdateLyrics(long SongID, String SongLyrics) {
final SQLiteDatabase database = mMusicDatabase.getWritableDatabase();
database.beginTransaction();
//onCreate(database);
Cursor c = getData(database, SongID);
if (c == null)
return false;
if (c.getCount() > 0) {
ContentValues contentValues = new ContentValues();
//contentValues.put(LyricsColumns.ID, SongID);
contentValues.put(LyricsColumns.Lyrics, "this is test");
result = database.update(LyricsColumns.NAME, contentValues, LyricsColumns.ID + "=?", new String[]{Long.toString(SongID)});
} else {
ContentValues contentValues = new ContentValues();
contentValues.put(LyricsColumns.ID, SongID);
contentValues.put(LyricsColumns.Lyrics, SongLyrics);
result = (int) database.insert(LyricsColumns.NAME, null, contentValues);
}
database.setTransactionSuccessful();
database.endTransaction();
return true;
}
public String getLyrics(long songid) {
String lyrics = "";
Cursor res = null;
try {
SQLiteDatabase db = mMusicDatabase.getReadableDatabase();
res= db.query(LyricsColumns.NAME,
new String[]{LyricsColumns.ID,LyricsColumns.Lyrics}, null, null, null, null,
LyricsColumns.ID + " DESC", "10");
//res = db.rawQuery("select * from " + LyricsColumns.NAME + " where "+ LyricsColumns.ID + "=" + songid + "", null);
if (res == null)
return "";
if (res.getCount() > 0) {
lyrics = res.getString(res.getColumnIndex(LyricsColumns.Lyrics));
}
} catch (Exception ex) {
}
return lyrics;
}
public Cursor getData(SQLiteDatabase database, long id) {
Cursor res = null;
String error = "";
try {
SQLiteDatabase db = mMusicDatabase.getReadableDatabase();
res = database.rawQuery("select * from " + LyricsColumns.NAME + " where songid=" + id + "", null);
} catch (Exception ex) {
error = ex.getMessage();
}
return res;
}
public interface LyricsColumns {
String NAME = "lyricsstore";
String ID = "songid";
String Lyrics = "lyrics";
}
}
MusicDBファイルを表示できますか? –
私は宣言している単純なクラスですpublic void onCreate(SQLiteDatabase db){LyricsStore.getInstance(mContext).onCreate(db); –
なぜSQLiteOpenHelperを拡張しなかったのですか? –