异常提取最后插入的id

时间:2017-12-01 11:50:58

标签: android sqlite android-sqlite

我想获取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"

2 个答案:

答案 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();
    }
}
相关问题