相关疑难解决方法(0)

Android SQLite LIKE转义通配符

在Android Jellybean 4.1上是否有可能逃避LIKE通配符并仍然喜欢使用索引?

使用:

where field like 'xyz\_abc'
Run Code Online (Sandbox Code Playgroud)

而不是:

where field like 'xyz_abc'
Run Code Online (Sandbox Code Playgroud)

逃避通配符是否适用于Android?如果通配符被转义,它还会使用索引吗?

我目前正在做的是:

where field like 'xyz_abc' and lower(field) = lower('xyz_abc')
Run Code Online (Sandbox Code Playgroud)

由于通配符,这是非常低效的.

谢谢

sqlite android android-sqlite

7
推荐指数
1
解决办法
3280
查看次数

如何在查询函数中使用LIKE子句

我正在制作一个应用程序,根据发件人编号在收件箱中搜索邮件.这是我的代码:

public void onClick(View v)
{
    Toast.makeText(this, "search", Toast.LENGTH_LONG).show();
    final Uri SMS_INBOX = Uri.parse("content://sms/inbox");

    String[] colList = {"address", "body"};

    Cursor c = getContentResolver().query(SMS_INBOX, colList, null, null,"DATE desc");

    String yz= String.valueOf(c.getCount());
    Toast.makeText(this, yz, Toast.LENGTH_LONG).show();

    if(c.moveToFirst())
    {
        Toast.makeText(this, searchtxt.getText(), Toast.LENGTH_LONG).show();

        for(int i=0;i<c.getCount();i++)
        {
            String number=c.getString(c.getColumnIndexOrThrow("address")).toString();
            boolean match = number.toUpperCase().indexOf(searchtxt.getText().toString()) != -1; 

            if (match)
            {
                Toast.makeText(this, String.valueOf(i), Toast.LENGTH_LONG).show();
                String  body= c.getString(c.getColumnIndexOrThrow("body")).toString();
                tv.setText(tv.getText() + "\n" + body);
            }
            c.moveToNext();
        }
    }
    else
    {
        Toast.makeText(this, "Inside else", Toast.LENGTH_LONG).show();
    }

    c.close();
}
Run Code Online (Sandbox Code Playgroud)

上面的代码工作正常,但它检索收件箱中的所有邮件.我希望它应该只检索那些与发件人号码匹配的邮件.为此,我尝试使用LIKE子句进行查询,但是使用它返回0条记录.使用LIKE子句的正确方法是什么.这是我尝试使用LIKE的代码

String[] colList = …
Run Code Online (Sandbox Code Playgroud)

sqlite android

6
推荐指数
1
解决办法
4357
查看次数

标签 统计

android ×2

sqlite ×2

android-sqlite ×1