sqlite查询大于或等于通配符

时间:2017-06-21 16:18:01

标签: sqlite search wildcard

我正在使用此代码:

SELECT *
FROM TableName
WHERE (ColumnName >= '' AND ColumnName < '豈')
   OR (ColumnName >= '' AND ColumnName < '')
   OR (ColumnName >= '' AND ColumnName < '');

来自this answer - 但它只返回以这些范围内的任何内容开头的条目。

我需要能够找到不以中的字符开头的条目包含上述范围内的字符。

我尝试过更改

'' AND ColumnName < '豈'

'%""%' AND CHS < '%"豈"%'

希望这会奏效 - 但显然不会那样。

我怎样才能让它发挥作用?

2 个答案:

答案 0 :(得分:1)

对于单个字符,您可以使用LIKE,但字符范围需要GLOB

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   >

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".UserAreaActivity"></activity>
    </application>

</manifest>

答案 1 :(得分:0)

使用标准SQL执行此操作的唯一方法是为范围内的每个字符包含OR子句:

SELECT * FROM Table WHERE
   ColName LIKE '%X%' OR
   ColName LIKE '%Y%' OR 
   ColName LIKE '%Z%' . . .

这很乏味,可能不实用,具体取决于你的范围内有多少个字符。

您可以看到的另外两个选项是正则表达式,在SQLite中用REGEXP运算符表示:

SELECT * FROM Table WHERE ColName REGEXP 'regular_expression'

或全文搜索,请在此处记录:http://www.sqlite.org/fts3.html