首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Android cursor.getInt

Android cursor.getInt
EN

Stack Overflow用户
提问于 2015-10-25 21:54:12
回答 2查看 939关注 0票数 0

我的功能有问题。我有一个函数来查找表的最大值(Id),它可以工作,但是对于另一个表,它不能工作。首先,我的数据库:

代码语言:javascript
复制
`//MAGASIN
public static final String MAGASIN_TABLE_CREATE = "CREATE TABLE "+ MAGASIN_TABLE_NAME + " ("+
            MAGASIN_KEY + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
            MAGASIN_NOM + " TEXT NOT NULL, " +
            MAGASIN_ADRESSE + " TEXT);";`

`

代码语言:javascript
复制
//LISTE`

    public static final String LISTE_TABLE_CREATE = "CREATE TABLE "+ LISTE_TABLE_NAME + " (" +
            LISTE_KEY + " INTEGER PRIMARY KEY AUTOINCREMENT, "+
            LISTE_NAME + " TEXT NOT NULL, "+
            LISTE_DATE_CREATION + " TEXT, "+
            LISTE_DATE_LAST_MODIFICATION + " TEXT, "+
            LISTE_IS_FINAL + " INTEGER, " +
            LISTE_NUM_MAGASIN + " INTEGER, " +
            "FOREIGN KEY("+ LISTE_NUM_MAGASIN +") REFERENCES MAGASIN("+ MAGASIN_KEY +"));";

在那之后,我的第一个作用是:

代码语言:javascript
复制
 public int selectMaxNumMagasin()
{
    Cursor cursor = mDb.rawQuery("select numMagasin as _id from magasin order by _id desc limit 1",null);
    int max;
    if (cursor == null)
    {
        max = 1;
        return max;
    }
    else
    {
        cursor.moveToFirst();
        max = cursor.getInt(0) + 1;
        cursor.close();
        return max;
    }
}

最后一个不起作用的

`

代码语言:javascript
复制
public int selectMaxNumListe()
    {
        Cursor cursor = mDb.rawQuery("select numListe as _id from liste order by _id desc limit 1",null);
        int max;
        if (cursor == null)
        {
            max = 1;
            return max;
        }
        else
        {
            cursor.moveToFirst();
            max = cursor.getInt(0);
            max += 1;
            cursor.close();
            return max;
        }
    }`

我做了一些测试,好像是

cursor.getInt(0);

卡住了。

希望有人能找到解决办法,谢谢;)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-26 09:50:20

rawQuery()总是返回有效的Cursor,或者抛出异常。检查null游标不是检查是否有结果的一种方法。

相反,检查moveToFirst()的结果值以检查非空游标.

还要注意,您可以完全使用SQL来完成您的工作,例如SELECT MAX(columnname)+1 FROM tablename

票数 0
EN

Stack Overflow用户

发布于 2015-10-26 09:23:34

在第二个函数中总是返回2,尝试返回2的最大整数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33335529

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档