我无法在Android上的SQLite数据库中插入数据

时间:2013-03-13 04:03:58

标签: android sqlite insert

我正在尝试将房间号码及其坐标插入数据库,然后访问它们以指示这些房间,但似乎我无法将数据插入到我的数据库中。

这是我的数据库处理程序:

public class MRLDatabaseHandler extends SQLiteOpenHelper {



    //private Context context;
    //private String locationsFile;


    private static final int DATABASE_VERSION = 1;

    private static final String DATABASE_NAME = "MRL_LocationsDB3";

    static final String TABLE_LOCATIONS = "locations"; //table name

    private static final String KEY_ID = "_GPSPoint_ID";
    private static final String KEY_RNUMBER = "_RNumber";
    private static final String KEY_LAT = "_Latitude";
    private static final String KEY_LONGI = "_Longitude";
    private static final String KEY_ALTI = "_Altitude";


    public MRLDatabaseHandler(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
        //this.context = context;
        //locationsFile = context.getString(R.string.mrl_locations);
    }


    @Override
    public void onCreate(SQLiteDatabase db) {
        String CREATE_LOCATIONS_TABLE = "CREATE TABLE " + TABLE_LOCATIONS + "("
                + KEY_ID + " INTEGER PRIMARY KEY AUTOINCREMENT," + KEY_RNUMBER + " TEXT," + KEY_LAT + " DOUBLE,"
                + KEY_LONGI + " DOUBLE,"  + KEY_ALTI + " DOUBLE"+ ")";
        db.execSQL(CREATE_LOCATIONS_TABLE);

        //populating the locations table
        /**MRL_LocationsLoader locationLoader = new MRL_LocationsLoader(context, db, locationsFile);
            try {
                locationLoader.loadData();

            }catch (IOException e){
                e.printStackTrace();
                } ***/


    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

        db.execSQL("DROP TABLE IF EXISTS " + TABLE_LOCATIONS);

        // Create tables again
        onCreate(db);

    }

//////CRUD IMPLEMETATION
    // Adding new coordinate
        void addCoordinate( MRL_LocationsModelClass point) {
            SQLiteDatabase db = this.getWritableDatabase();

            ContentValues values = new ContentValues();
            values.put(KEY_ID , point.get_GPSPoint_ID());
            values.put(KEY_RNUMBER, point.get_RNumber()); 
            values.put(KEY_LAT, point.get_Latitude()); 
            values.put(KEY_LONGI, point.get_Longitude()); 
            values.put(KEY_ALTI, point.get_Altitude()); 


            // Inserting Row
            db.insert(TABLE_LOCATIONS, null, values);
            db.close(); // Closing database connection
        }

    // Getting single coordinate from SQLite database
    MRL_LocationsModelClass getPoint(int id) {
        SQLiteDatabase db = this.getReadableDatabase();

        Cursor cursor = db.query(TABLE_LOCATIONS, new String[] { KEY_ID,
                KEY_RNUMBER, KEY_LAT, KEY_LONGI, KEY_ALTI }, KEY_ID + "=?",
                new String[] { String.valueOf(id) }, null, null, null, null);
        if (cursor != null)
            cursor.moveToFirst();

        MRL_LocationsModelClass locationsModelClass = new MRL_LocationsModelClass(
                Integer.parseInt(cursor.getString(0)), cursor.getString(1),
                Double.parseDouble(cursor.getString(2)),
                Double.parseDouble(cursor.getString(3)),
                Double.parseDouble(cursor.getString(4)));
        // return contact
        return locationsModelClass;

    }

以下是使用它的课程:

public class DrawPath extends Activity {
     MRLDatabaseHandler db = new MRLDatabaseHandler(this);
    int dest = 9, src = 6;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        // Inserting Coordinates
                Log.d("Insert: ", "Inserting ..");
                db.addCoordinate(new MRL_LocationsModelClass("L101", -12.804646,28.240218,  (double) 1223));
                db.addCoordinate(new MRL_LocationsModelClass("C102", -12.8048,28.240736, (double) 1227));
                db.addCoordinate(new MRL_LocationsModelClass("Z103", -12.805274,28.240529, (double) 1225));
                db.addCoordinate(new MRL_LocationsModelClass("A104", -12.805347,28.238821, (double) 1232));
                db.addCoordinate(new MRL_LocationsModelClass("NH201",-12.804497,28.24068, (double) 1222));



        MRL_LocationsModelClass srcPoint = db.getPoint(src);
        MRL_LocationsModelClass destPoint = db.getPoint(dest);
        SharedData data = SharedData.getInstance();
        data.setAPIKEY("0Fm62I15vXD_pVpF8WXdTK0ooUd2Wm8rxsT3Kvg");
        data.setSrc_lat(srcPoint.get_Latitude());
        data.setSrc_lng(srcPoint.get_Longitude());
        data.setDest_lat(destPoint.get_Latitude());
        data.setDest_lng(destPoint.get_Longitude());
        startActivity(new Intent(DrawPath.this,RoutePath.class)); 

    }



}

这是我的logcat:

03-13 05:19:26.337: D/Insert:(618): Inserting ..
03-13 05:19:30.940: E/Database(618): Error inserting _Longitude=28.240736 _RNumber=C102 _Altitude=1227.0 _Latitude=-12.8048 _GPSPoint_ID=0
03-13 05:19:30.940: E/Database(618): android.database.sqlite.SQLiteConstraintException: error code 19: constraint failed
03-13 05:19:30.940: E/Database(618):    at android.database.sqlite.SQLiteStatement.native_execute(Native Method)
03-13 05:19:30.940: E/Database(618):    at android.database.sqlite.SQLiteStatement.execute(SQLiteStatement.java:55)
03-13 05:19:30.940: E/Database(618):    at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1549)
03-13 05:19:30.940: E/Database(618):    at android.database.sqlite.SQLiteDatabase.insert(SQLiteDatabase.java:1410)
03-13 05:19:30.940: E/Database(618):    at com.agarwal.route.MRLDatabaseHandler.addCoordinate(MRLDatabaseHandler.java:84)
03-13 05:19:30.940: E/Database(618):    at com.agarwal.route.DrawPath.onCreate(DrawPath.java:20)
03-13 05:19:30.940: E/Database(618):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-13 05:19:30.940: E/Database(618):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
03-13 05:19:30.940: E/Database(618):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
03-13 05:19:30.940: E/Database(618):    at android.app.ActivityThread.access$2300(ActivityThread.java:125)
03-13 05:19:30.940: E/Database(618):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
03-13 05:19:30.940: E/Database(618):    at android.os.Handler.dispatchMessage(Handler.java:99)
03-13 05:19:30.940: E/Database(618):    at android.os.Looper.loop(Looper.java:123)
03-13 05:19:30.940: E/Database(618):    at android.app.ActivityThread.main(ActivityThread.java:4627)
03-13 05:19:30.940: E/Database(618):    at java.lang.reflect.Method.invokeNative(Native Method)
03-13 05:19:30.940: E/Database(618):    at java.lang.reflect.Method.invoke(Method.java:521)
03-13 05:19:30.940: E/Database(618):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
03-13 05:19:30.940: E/Database(618):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
03-13 05:19:30.940: E/Database(618):    at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:2)

您尝试一遍又一遍地向INTEGER PRIMARY KEY列添加值0。这会导致约束失败。

要解决此问题,请从addCoordinate()

中删除此行
values.put(KEY_ID , point.get_GPSPoint_ID());

要捕获自动生成的id值,请从insert()

中获取返回值
long id = db.insert(TABLE_LOCATIONS, null, values);
point.set_GPSPoint_ID(id);

(旧问题但是被编辑搞砸了。)