2

我的应用程序与 sql lite 数据库一起使用我在 SQlite 开发人员中编写了查询并对其进行了测试,它工作正常,但是当我在 android 上编写它时,它只返回一个值而不是几个值。android查询有什么问题?

程序代码

SELECT DISTINCT
    m._id,
    m.name,
    m.the_best_time,
    m.the_worse_time,
    count(p._id) as qPoints
FROM sickness AS s
INNER JOIN list_of_sicknesses AS l
    ON s._id = l.sickness_id
INNER JOIN point AS p
    ON p.sickness_list = l.number
INNER JOIN meridian AS m
    ON m._id = p.meridian_id
WHERE s.sick = 'value'
GROUP BY
    m.name,
    m.the_best_time,
    m.the_worse_time,m._id

安卓查询代码

 String query="select distinct m." +MeridianDB.ID+
            ",m."+MeridianDB.NAME+",m."+MeridianDB.BEST_TIME+
            ",m."+MeridianDB.WORSE_TIME+",count(p."+PointDB.ID+") as         qPoints from "+
            SicknessDB.TABLE_NAME+" as s inner join "+ListOFSicknessDB.TABLE_NAME+
            " as l on s."+SicknessDB.ID+" = l."+ListOFSicknessDB.SICKNESS_ID+
            " inner join "+PointDB.TABLE_NAME+" as p on p."+PointDB.SICKNESS_LIST+
            " = l."+ListOFSicknessDB.NUMBER+" inner join "+MeridianDB.TABLE_NAME+
            " as m on m."+MeridianDB.ID+" = p."+PointDB.MERIDIAN_ID+" where s."+
            SicknessDB.NAME+"=? group by m."+MeridianDB.ID+",m."+MeridianDB.NAME+
            ",m."+MeridianDB.BEST_TIME+",m."+MeridianDB.WORSE_TIME; 
4

1 回答 1

0

尝试删除DISTINCT子句(因为您已经在使用GROUP BY)我不确定这部分是否存在问题,但DISTINCT同时GROUP BY在一个查询中使用和通常不是最佳做法

于 2013-02-01T07:50:39.040 回答