Android Studioで簡単なゲームを作っています。
勝敗が出た日付と勝敗をSQLiteDatabaseに挿入して、読み出したいのですが、挿入の段階で「no such table」ということでSQLExceptionが出てしまいます。原因がわからないので教えていただけると幸いです。
java
1package to.msn.wings.sanmokunarabe; 2 3import android.content.Context; 4import android.database.sqlite.SQLiteDatabase; 5import android.database.sqlite.SQLiteOpenHelper; 6 7public class OperateDatabase extends SQLiteOpenHelper { 8 static final private String DBNAME = "sanmoku_database"; 9 static final private int VERSION = 1; 10 11 OperateDatabase(Context context){ 12 super(context, DBNAME, null, VERSION); 13 } 14 15 @Override 16 public void onOpen(SQLiteDatabase db) { 17 super.onOpen(db); 18 } 19 20// PRIMARY KEY AUTOINCREMENT 21 @Override 22 public void onCreate(SQLiteDatabase sqLiteDatabase) { 23 sqLiteDatabase.execSQL("create table testtest(" + 24 "id integer primary key autoincrement," + 25 "date text," + "result text);"); 26 } 27 28 @Override 29 public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) { 30 sqLiteDatabase.execSQL("drop table if exists testtest"); 31 onCreate(sqLiteDatabase); 32 } 33 34} 35
java
1package to.msn.wings.sanmokunarabe; 2 3import androidx.appcompat.app.AppCompatActivity; 4import androidx.constraintlayout.widget.ConstraintLayout; 5 6import android.content.Intent; 7import android.database.Cursor; 8import android.database.SQLException; 9import android.database.sqlite.SQLiteDatabase; 10import android.database.sqlite.SQLiteStatement; 11import android.media.MediaPlayer; 12import android.os.Bundle; 13import android.os.VibrationEffect; 14import android.os.Vibrator; 15import android.view.Menu; 16import android.view.MenuItem; 17import android.view.View; 18import android.widget.Button; 19import android.widget.TextView; 20import android.widget.Toast; 21 22import java.text.SimpleDateFormat; 23import java.util.ArrayList; 24import java.util.Date; 25import java.util.Random; 26import java.util.TimeZone; 27 28public class MainActivity extends AppCompatActivity { 29 private OperateDatabase operateDatabase = null; 30 Date date; 31 SimpleDateFormat sdf; 32 TimeZone timeZone; 33 34 @Override 35 protected void onCreate(Bundle savedInstanceState) { 36 super.onCreate(savedInstanceState); 37 setContentView(R.layout.activity_main); 38 39 operateDatabase = new OperateDatabase(this); 40 41 } 42 43 44 //こちらのメソッドは勝敗が出た後呼ばれ、引数に文字列("勝ち", "負け", "引き分け")のいずれかが入ります。 45 public void registerData(String result){ 46 date = new Date(); 47 timeZone = TimeZone.getTimeZone("Asia/Tokyo"); 48 sdf = new SimpleDateFormat("y年MM月dd日(E)HH時mm分"); 49 sdf.setTimeZone(timeZone); 50 String now = sdf.format(date); 51 52 //こちらのtry文で例外が出てしまいます。 53 try(SQLiteDatabase db = operateDatabase.getWritableDatabase(); 54 SQLiteStatement sql = db.compileStatement( 55 "insert into testtest(date, result) values(?, ?)" 56 )){ 57 sql.bindString(1, now); 58 sql.bindString(2, result); 59 sql.executeInsert(); 60 } 61 62 } 63 64 65 66}