Android SQLite选择查询中的撇号
我对SQLite和一些定制SQL有问题:Android SQLite选择查询中的撇号,android,sqlite,Android,Sqlite,我对SQLite和一些定制SQL有问题: public Cursor getExistingSpeciesDetails(String sub_id, String english_name) { Cursor c = mDb.rawQuery( "SELECT mobileobs.how_many, mobileobs.comment, mobileobs.sensitive, " + "mobileobs.breedin
public Cursor getExistingSpeciesDetails(String sub_id, String english_name) {
Cursor c = mDb.rawQuery(
"SELECT mobileobs.how_many, mobileobs.comment, mobileobs.sensitive, "
+ "mobileobs.breeding_evidence from mobileobs "
+ "WHERE mobileobs.sub_id = '" + sub_id
+ "' and mobileobs.english_name = '" + english_name
+ "'", null);
return c;
}
我的问题是英文名称中的一个撇号(Cetti's Warbler)导致SQL中出现错误(强制关闭我的Android应用程序)。有没有办法避开这类子句中的撇号
为此,您需要使用SQLIte的参数注入。例如:
Cursor c = mDb.rawQuery(
"SELECT mobileobs.how_many, mobileobs.comment, mobileobs.sensitive, "
+ "mobileobs.breeding_evidence from mobileobs "
+ "WHERE mobileobs.sub_id = ? AND mobileobs.english_name = ?"
, new String[]{sub_id, english_name});
或按以下方式更改输入参数:
Cetti''s Warbler
为此,您需要使用SQLIte的参数注入。例如:
Cursor c = mDb.rawQuery(
"SELECT mobileobs.how_many, mobileobs.comment, mobileobs.sensitive, "
+ "mobileobs.breeding_evidence from mobileobs "
+ "WHERE mobileobs.sub_id = ? AND mobileobs.english_name = ?"
, new String[]{sub_id, english_name});
或按以下方式更改输入参数:
Cetti''s Warbler
尝试使用
wherergs
,将查询中的null
替换为新字符串[]{sub\u id,english\u name}
还将复杂的“
删除为类似的内容,其中id=?和name=?
尝试使用wherergs
,将查询中的null
替换为新字符串[]{sub\u id,english\u name}
还将复杂的“
删除为类似的内容,其中id=?和name=?
谢谢-将尝试一下。谢谢-将尝试一下。