在我的项目中使用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();
}
}
}
});
只想指出一切正常,直到我的笔记本电脑粉碎,我不得不改为另一台。
感谢您的帮助。
答案 0 :(得分:1)
我认为您的问题在于列顺序,最重要的是reidriction为rowid列的别名,在您的情况下 Id 列( Id INTEGER PRIMARY KEY AUTOINCREMENT
定义 Id 作为rowid列的别名)。
SQLite版本3数据库中的任何列,但INTEGER PRIMARY除外 KEY列,可用于存储任何存储类的值。
这样的列只能存储整数值。 String sql = "INSERT INTO PHOTO VALUES(NULL,?,?,?,?)";
等同于按以下方式插入值: -
你可以解决这个问题,要么提供列名,要么重新排序列以匹配它们的定义顺序(前者可以说是更好的做法)。
因此,以下任何一项都应解决问题: -
String sql = "INSERT INTO PHOTO (Id, name, lat, lon, image) VALUES(NULL,?,?,?,?)";
或: -
String sql = "INSERT INTO PHOTO VALUES(?,?,?,?,NULL)";