markdowneide 2013-04-03 09:37 采纳率: 0%
浏览 5166

Android SQLiteDatabase 中使用 like 查询

在名字表中有3个名字:Allakhazam, Beatbox 和 Cunning

public Cursor fetchNamesByConstraint(String filter) {

    mDb.query(true, DATABASE_NAMES_TABLE, new String[] { KEY_ROWID,
            KEY_NAME }, KEY_NAME + " LIKE ?",
            new String[] { filter }, null, null, null,
            null);

    return mCursor;
}

我使用A作为filter调用函数,但是光标返回一个0计数,这时候本应该是返回1的。如何修改代码呢?

  • 写回答

1条回答

  • LiDaming_and 2013-04-07 02:42
    关注

    这个语句将会返回所有的记录,这些记录的 keyname 是指定的字符串。如果你使用 wild card,然后就可以获得预期结果:

    mDb.query(true, DATABASE_NAMES_TABLE, new String[] { KEY_ROWID,
                KEY_NAME }, KEY_NAME + " LIKE ?",
                new String[] { filter+"%" }, null, null, null,
                null);
    

    在filter 中会显示所有的记录

    mDb.query(true, DATABASE_NAMES_TABLE, new String[] { KEY_ROWID,
                KEY_NAME }, KEY_NAME + " LIKE ?",
                new String[] {"%"+ filter+ "%" }, null, null, null,
                null);
    
    评论

报告相同问题?

悬赏问题

  • ¥15 用matlab 设计一个不动点迭代法求解非线性方程组的代码
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题
  • ¥15 教务系统账号被盗号如何追溯设备
  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效