插入时数据类型不匹配(代码20)

时间:2018-02-17 15:50:09

标签: android sqlite insert android-sqlite mismatch

在我的项目中使用sqlite数据库来保存图片及其位置。我在尝试将数据插入数据库时​​收到此错误:

E/SQLiteLog: (20) statement aborts at 5: [INSERT INTO PHOTO VALUES(NULL,?,?,?,?)] datatype mismatch
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
                  Process: com.example.tomer.finalproject, PID: 18550
                  android.database.sqlite.SQLiteDatatypeMismatchException: datatype mismatch (code 20)
                      at android.database.sqlite.SQLiteConnection.nativeExecuteForLastInsertedRowId(Native Method)
                      at android.database.sqlite.SQLiteConnection.executeForLastInsertedRowId(SQLiteConnection.java:786)
                      at android.database.sqlite.SQLiteSession.executeForLastInsertedRowId(SQLiteSession.java:926)

这是我的代码:

insert方法,它位于名为SQLiteOpenHelper的类中:

public void insertData(String name, String lat, String lon, byte[] image) {

        SQLiteDatabase database = getWritableDatabase();
        String sql = "INSERT INTO PHOTO VALUES(NULL,?,?,?,?)";
        SQLiteStatement statement = database.compileStatement(sql);
        statement.clearBindings();
        statement.bindString(1, name);
        statement.bindString(2, lat);
        statement.bindString(3, lon);
        statement.bindBlob(4, image);

        statement.executeInsert();

}

我在一个按钮中调用它来添加'来自另一项活动:

这2行属于onCreate

sqLiteHelper=new SQLiteHelper(this,"GalleryDB.sqlite",null,1);
        sqLiteHelper.queryData("CREATE TABLE IF NOT EXISTS PHOTO (name VARCHAR,lat VARCHAR,lon VARCHAR,image BLOG,Id INTEGER PRIMARY KEY  AUTOINCREMENT)");

这是我的添加按钮:

        btnadd.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
               GPStracker g = new GPStracker(getApplicationContext());
               Location l = g.getLocation();
                if (l != null) {
                    double lat = l.getLatitude();
                    double lon = l.getLongitude();
                     String stLat= String.valueOf(lat);
                     String stLon= String.valueOf(lon);
                    try{
                Toast.makeText(getApplicationContext(), "Saved To Gallery!", Toast.LENGTH_SHORT).show();
                 sqLiteHelper.insertData(etname.getText().toString().trim(),stLat.trim(),stLon.trim(),imageViewToByte(imageView));

                   }
                    catch (Exception e){
                       e.printStackTrace();
                    }


                }


                }
        });

只想指出一切正常,直到我的笔记本电脑粉碎,我不得不改为另一台。

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

我认为您的问题在于列顺序,最重要的是reidriction为rowid列的别名,在您的情况下 Id 列( Id INTEGER PRIMARY KEY AUTOINCREMENT定义 Id 作为rowid列的别名)。

  • 注意其他列可以按以下方式存储任何值: -
    •   

      SQLite版本3数据库中的任何列,但INTEGER PRIMARY除外   KEY列,可用于存储任何存储类的值。

    • Datatypes In SQLite Version 3

这样的列只能存储整数值。 String sql = "INSERT INTO PHOTO VALUES(NULL,?,?,?,?)";等同于按以下方式插入值: -

  • NULL进入名称
  • 传递给 lat
  • 的名称
  • lat,传递给 lon
  • lon,如同通过,进入图像
  • 图片已传递到Id列( bye [] 无法存储在Id列中

你可以解决这个问题,要么提供列名,要么重新排序列以匹配它们的定义顺序(前者可以说是更好的做法)。

因此,以下任何一项都应解决问题: -

String sql = "INSERT INTO PHOTO (Id, name, lat, lon, image) VALUES(NULL,?,?,?,?)";

或: -

String sql = "INSERT INTO PHOTO VALUES(?,?,?,?,NULL)";