我想获取sqlite中最后一个插入行的id但是我得到异常没有这样的专栏提取它。我已经发布了我的sqlite表,我想要获取id和异常的方法。我尝试了很多堆栈中的答案但没有用。请帮助我
`E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.opentok.example.efflorescence.myaudiotranscription, PID: 20655
android.database.sqlite.SQLiteException: no such column: _id (code 1): , while compiling: SELECT _id FROM calls
at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:898)
at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:509)
at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:37)
at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:44)
at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1346)
at android.database.sqlite.SQLiteDatabase.queryWithFactory(SQLiteDatabase.java:1193)
at android.database.sqlite.SQLiteDatabase.query(SQLiteDatabase.java:1064)
at android.database.sqlite.SQLiteDatabase.query(SQLiteDatabase.java:1232)
at com.opentok.example.efflorescence.myaudiotranscription.database.DBHelper.getLastId(DBHelper.java:79)
at com.opentok.example.efflorescence.myaudiotranscription.AudioCallActivity$3.run(AudioCallActivity.java:199)
at android.os.Handler.handleCallback(Handler.java:815)
at android.os.Handler.dispatchMessage(Handler.java:104)
at android.os.Looper.loop(Looper.java:194)
at android.app.ActivityThread.main(ActivityThread.java:5637)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)`
例外
public class DBHelper extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "MyDBName.db";
public static final String CALLS_TABLE_NAME = "calls";
public static final String CALLS_COLUMN_ID = "id";
public static final String CALLS_COLUMN_NAME = "name";
public static final String CALLS_COLUMN_TIME = "time";
public static final String CALLS_COLUMN_TYPE = "type";
public int numRows;
ArrayList<String> array_list = new ArrayList<String>();
private HashMap hp;
public DBHelper(Context context) {
super(context, DATABASE_NAME, null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
db.execSQL(
"create table calls " +
"(id integer primary key, name text,time text, type text,archiveId text)"
);
}
我的sqlite表
"../node_modules/carbon-components/scss/globals/scss/styles.scss"
答案 0 :(得分:0)
您必须将主键 ID 更改为 _id ,请尝试以下代码
public static final String CALLS_COLUMN_ID = "_id";//change here
public static final String CALLS_COLUMN_NAME = "name";
public static final String CALLS_COLUMN_TIME = "time";
public static final String CALLS_COLUMN_TYPE = "type";
public int numRows;
ArrayList<String> array_list = new ArrayList<String>();
private HashMap hp;
public DBHelper(Context context) {
super(context, DATABASE_NAME, null, 2);// also change db version
}
更改db版本
答案 1 :(得分:0)
您正在尝试阅读名为_id
的列,但您实际拥有的列是id
。
无论如何,不是直接读取所有表行,而是直接读取最后一个值会快得多:
long getLastId() {
SQLiteDatabase db = this.getReadableDatabase();
try {
return DatabaseUtils.longForQuery(db,
"SELECT max(id) FROM calls", null);
} finallly {
db.close();
}
}