我尝试使用以下选择对 android sqlite 数据库进行查询,但当我将其放入 eclipse 中时,它仅显示错误。
stmt = "SELECT * FROM user_zones JOIN pos WHERE user_zones.zone_id = (
CASE
WHEN user_zones.type_zone_id = 'Zone' THEN pos.zone_id
WHEN user_zones.type_zone_id = 'Area' THEN pos.area_id
WHEN user_zones.type_zone_id = 'Town' THEN pos.town_id
WHEN user_zones.type_zone_id = 'MicroZone' THEN pos.microzone_id END) AND user_zones.user_id = '"+id_user+"'";
有谁知道上面的语法有什么问题吗?谢谢
编辑:我什至无法运行代码,有语法错误!
错误:找不到符号类 CASE
unclosed character literal
cannot find symbol class 'THEN'
expected ';' ....and so on
最佳答案
如果这确实是您粘贴到 Java 源代码中的内容,那么您的问题是 Java 中的字符串文字不能跨越多行。您必须为每一行使用单独的字符串文字将其拆分,并使用 +
运算符将它们全部粘合在一起。像这样。
stmt = "SELECT * FROM user_zones JOIN pos WHERE user_zones.zone_id = (" +
" CASE" +
...
关于java - Android 上 SQLite 查询的语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12034902/