Android 数据不会插入到预构建的数据库中

Android 数据不会插入到预构建的数据库中,android,sqlite,Android,Sqlite,在这里,我想在我的数据库中插入一些内容。我也用过 作为参考,但这是徒劳的 但这是我的错误日志 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.

在这里,我想在我的数据库中插入一些内容。我也用过 作为参考,但这是徒劳的

但这是我的错误日志

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
提前谢谢。
很抱歉插入了错误的链接

数据,但由于DeptId是主键,因此在Dept表中插入重复数据时出错

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

按如下方式打开数据库

 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);
无需过度使用此功能。只需使用内置的

而且


更改打开数据库进行写入的模式。

数据库未打开
--在尝试插入数据之前是否打开了与数据库的连接?是的,我打开了@George look here myDbHelper.openDataBase();myDbHelper.insertData(10,“kaushik”,“dhor sala”,22.332322332,88.23232);在DatabaseProtoActivity中。我是说,您的数据正确插入了一次,但因为您的代码试图在表中插入相同的数据,并且因为DeptId是主数据库,所以您的数据库抛出Exception.DeptId?为什么没有这样的领域?n顺便说一句,food_joint_id是这里的主键。但我没有在tht字段中插入任何数据。检查您上传到MediaFire的代码这里是SQL查询创建表Dept(DeptID INTEGER主键,DeptName文本)
public synchronized SQLiteDatabase getWritableDatabase()
checkDB = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READWRITE);

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