我正在使用此代码:
SELECT *
FROM TableName
WHERE (ColumnName >= '' AND ColumnName < '豈')
OR (ColumnName >= '' AND ColumnName < '')
OR (ColumnName >= '' AND ColumnName < '');
来自this answer - 但它只返回以这些范围内的任何内容开头的条目。
我需要能够找到不以中的字符开头的条目但包含上述范围内的字符。
我尝试过更改
'' AND ColumnName < '豈'
到
'%""%' AND CHS < '%"豈"%'
希望这会奏效 - 但显然不会那样。
我怎样才能让它发挥作用?
答案 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。