Я разрабатываю приложение, которое отслеживает текущее положение пользователя и сохраняет его в базе данных SQLite.Все работает нормально, но теперь у меня проблема при запросе базы данных для трека с более чем 1000 записями, это занимает почти 1,5 минуты.На моем рабочем столе это занимает всего 1 секунду.
Я знаю, что это запрос с большим количеством подвыборов, но я не смог получить правильный результат другим способом.По моему мнению, это относится к агрегатным функциям, таким как avg () и sum ().
Вот мой запрос:
Cursor c = readableDB
.rawQuery(
"SELECT DISTINCT t._id , title , strftime('%Y-%m-%d' , starttime , 'unixepoch' , 'localtime') as date , description, "
+ "round((SELECT sum(distToPrev)/1000 FROM positions p WHERE p.trackid=t._id) , 2) as distance , "
+ "(SELECT count(latitude) FROM positions p WHERE p.trackid=t._id) as waypoints, "
+ "(SELECT (avg(speed)*3.6) FROM positions p WHERE p.trackid=t._id) as avgspeed, "
+ "(SELECT (max(speed)*3.6) FROM positions p WHERE p.trackid=t._id) as maxspeed, "
+ "(SELECT sum(altitudeUP) FROM positions p WHERE p.trackid=t._id) as climb , "
+ "(SELECT avg(heartbeat) FROM heartbeats h WHERE h.trackid=t._id) as avgheartbeat , "
+ "(SELECT max(heartbeat) FROM heartbeats h WHERE h.trackid=t._id) as maxheartbeat , "
+ "(SELECT avg(cadence) FROM heartbeats h WHERE h.trackid=t._id) as avgcadence "
+ "FROM tracks t LEFT JOIN heartbeats h ON t._id = h.trackid WHERE t._id = ?",
new String[]{String.valueOf(trackId)});
c.moveToFirst();
Как я могу оптимизировать этот запрос?Я попробовал это уже таким образом, но тогда результат был неправильным, и это заняло столько же времени.
SELECT t._id , title , strftime('%Y-%m-%d' , starttime , 'unixepoch' , 'localtime') as date , description,
sum(distToPrev)/1000 as distance ,
count(latitude) as waypoints,
(avg(speed)*3.6) as avgspeed,
(max(speed)*3.6) as maxspeed,
sum(altitudeUP) as climb ,
avg(heartbeat) as avgheartbeat ,
max(heartbeat) as maxheartbeat ,
avg(cadence) as avgcadence
FROM tracks t
LEFT JOIN heartbeats h ON t._id = h.trackid
INNER JOIN positions p ON t._id = p.trackid
WHERE t._id = ?
Уже 2 часа я ищу решение и не знаю, что я 'Я делаю неправильно.Может быть, мне нужно сделать перерыв.
РЕДАКТИРОВАТЬ:
Вот мои заявления создания:
CREATE TABLE heartbeats(_id INTEGER PRIMARY KEY AUTOINCREMENT, trackid INTEGER NOT NULL, heartbeat INTEGER NOT NULL, cadence INTEGER, timestamp TIMESTAMP);
CREATE TABLE positions(_id INTEGER PRIMARY KEY AUTOINCREMENT, trackid INTEGER NOT NULL, longitude REAL NOT NULL, latitude REAL NOT NULL, altitude REAL, altitudeUP REAL, speed REAL, accuracy REAL, distToPrev REAL, timestamp TIMESTAMP);
CREATE TABLE tracks(_id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT NOT NULL, description TEXT, starttime DATETIME NOT NULL, endtime DATETIME);