Ich habe eine Anwendung, die gut funktioniert. Aber ich vermute, dass ich es verbessern kann, wenn ich Abfragen auf die Datenbank optimiere. Und ich brauche Vorschläge.Sqlite Android Optimierung
Dieser Teil meiner "select-Abfrage" ist:
private static final String SELECT = "SELECT " +
"dz.first_id AS first_id, " +
"dz._id AS _id, " +
"dz.att1 AS att1, " +
"dz.att2 AS att2, " +
"dz.att3 AS att3, " +
"dz.att4 AS att4, " +
"dz.att5 AS att5, " +
"d.var1 AS var1, " +
"d.name AS name, " +
"d.last_update AS last_update, " +
"d.image_url AS image_url, " +
"d.image_highlighted_url AS image_highlighted_url, " +
"d.var2 AS var2, " +
"d.type AS type, " +
"d.state AS state, " +
"d.sync AS sync, " +
"d.var3 AS var3 " +
"FROM table1 dz INNER JOIN table2 d " +
"ON d._id = dz.first_id ";
Cursor result = conn.rawQuery(SELECT, null);
* table1
und table2
haben einfache Erstellung: nur eine _id integer PRIMARY KEY AUTOINCREMENT NOT NULL
Es ist nützlich, Ansichten zu benutzen? Irgendwelche anderen Vorschläge?
Danke.
Sind Sie auf der Suche nach Abfrageoptimierungen? Sei genau. Können Sie das Tabellenschema auch posten? – bpachev
Indizieren der WHERE und der JOIN ist ein Lebensretter. Aber auch StringBuilders anstelle von String-Verkettungen verwenden. –
Ich suche nach Abfrageoptimierungen ja. Die Erstellung der Tabellen ist einfach, nur ein _id-Integer PRIMARY KEY AUTOINCREMENT NICHT NULL –