2012-05-04 8 views
2

Here is my projectデータは、構築済みのデータベースここ

に挿入されません私は私のデータベースに何かを挿入します。私は参考としてもthis link を使用しましたが、無駄になります。

ただし、ここにはエラーログがあります。

05-04 16:53:20.272: E/AndroidRuntime(18378): FATAL EXCEPTION: main 
05-04 16:53:20.272: E/AndroidRuntime(18378): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.crews.databaseproto.activity/com.crews.databaseproto.activity.DatabaseProtoActivity}: java.lang.IllegalStateException: database not open 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.os.Handler.dispatchMessage(Handler.java:99) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.os.Looper.loop(Looper.java:130) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.app.ActivityThread.main(ActivityThread.java:3687) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at java.lang.reflect.Method.invokeNative(Native Method) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at java.lang.reflect.Method.invoke(Method.java:507) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at dalvik.system.NativeStart.main(Native Method) 
05-04 16:53:20.272: E/AndroidRuntime(18378): Caused by: java.lang.IllegalStateException: database not open 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.database.sqlite.SQLiteDatabase.endTransaction(SQLiteDatabase.java:555) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at com.crews.databaseproto.activity.DataBaseHelper.insertData(DataBaseHelper.java:153) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at com.crews.databaseproto.activity.DatabaseProtoActivity.onCreate(DatabaseProtoActivity.java:37) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
05-04 16:53:20.272: E/AndroidRuntime(18378): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615) 
05-04 16:53:20.272: E/AndroidRuntime(18378): ... 11 more 

ありがとうございます。 間違ったリンクのため申し訳ありません

+2

'データベースが開かない ' - データを挿入する前にデータベースへの接続をオープンしましたか? –

+0

はい@Georgeはここを見ました。myDbHelper.openDataBase(); \t \t \t myDbHelper.insertData(10、 "Kaushikによる"、 "DHORサラ"、22.332322332、88.2323232)。 DatabaseProtoActivityに格納されます。 – kaushikSuman

答えて

1
public synchronized SQLiteDatabase getWritableDatabase() 
を次のように

この機能をオーバーライドする必要はありません。ビルド済みのものを使用してください。また

、あなたが書くためにDBを開いている

checkDB = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READWRITE); 

myDataBase = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READWRITE); 

変更モード。

0

データが挿入されているが、DEPTIDが主キーであるため、テーブル内の重複データを挿入するためにエラーを与えている部門

05-05 00:01:09.783: E/Database(1011): at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1562) 
+0

私はあなたのデータが一度正しく挿入されたと言っていますが、コードでは同じデータをテーブルに挿入しようとしているため、DeptIdがプライマリであるためDBがExceptionをスローします。 –

+0

DeptId?どうしてそんなフィールドがないのですか? nはfood_joint_idがここのプライマリキーです。しかし、私はthtフィールドにデータを挿入していません。 – kaushikSuman

+0

あなたのコードをチェックしてくださいMediaFireにアップロードされたのは、SQLクエリCREATE TABLE Dept(DeptID INTEGER PRIMARY KEY、DeptName TEXT)です。 –

1

オープンデータベース

SqliteDatabase db=myDbHelper.getWritableDatabase(); 
ContentValues cv=new ContentValues(); 
cv.put(COLUMN_NAME,10); 
cv.put(COLUMN_NAME,"Kaushik"); 
cv.put(COLUMN_NAME,"dhor sala"); 
cv.put(COLUMN_NAME,22.332322332); 
cv.put(COLUMN_NAME,88.2323232); 
float row id=db.insert(TABLE_NAME,null,cv); 
関連する問題