Ich habe den folgenden Code wurde unter Verwendung einer Tabelle abzufragen:Android SQLite "order by" berechnete Spalte in Union-Abfrage
public Cursor fetchFilteredItemsNearSortedByDistance(String strTable, String[] strArrayFields, String strField, String strCriterion, double dblCentreEasting, double dblCentreNorthing, double dblRadius) {
String strSQL = "Easting > " + Double.toString(dblCentreEasting-dblRadius);
strSQL += " AND Easting < " + Double.toString(dblCentreEasting+dblRadius);
strSQL += " AND Northing > " + Double.toString(dblCentreNorthing-dblRadius);
strSQL += " AND Northing < " + Double.toString(dblCentreNorthing+dblRadius);
strSQL += " AND " + strField + " LIKE '%" + strCriterion + "%'";
strSQL += " ORDER BY ";
strSQL += "((Easting - " + Double.toString(dblCentreEasting)+")";
strSQL += " * (Easting - " + Double.toString(dblCentreEasting)+")";
strSQL += " + (Northing - " + Double.toString(dblCentreNorthing)+")";
strSQL += " * (Northing - " + Double.toString(dblCentreNorthing)+"))";
strSQL += " COLLATE NOCASE";
return myDbHelper.myDataBase.query(strTable, strExtendedArrayFields, strSQL, null, null, null, null);
}
Der obige Code hat zufriedenstellend gearbeitet. Allerdings möchte ich jetzt die Idee, eine Vereinigung von zwei oder mehr Tabellen zu erweitern, und haben den folgenden Code versucht:
public Cursor fetchFilteredPOIsNearSortedByDistance(String strTable, String[] strArrayFields, String strField, String strCriterion, double dblCentreEasting, double dblCentreNorthing, double dblRadius) {
String strSQL = "SELECT * FROM TableA ";
strSQL += "UNION SELECT * FROM TableB ";
strSQL += "WHERE (Easting > " + Double.toString(dblCentreEasting-dblRadius);
strSQL += " AND Easting < " + Double.toString(dblCentreEasting+dblRadius);
strSQL += " AND Northing > " + Double.toString(dblCentreNorthing-dblRadius);
strSQL += " AND Northing < " + Double.toString(dblCentreNorthing+dblRadius);
strSQL += " AND " + strField + " LIKE '%" + strCriterion + "%') ";
strSQL += " ORDER BY ";
strSQL += "((Easting - " + Double.toString(dblCentreEasting)+")";
strSQL += " * (Easting - " + Double.toString(dblCentreEasting)+")";
strSQL += " + (Northing - " + Double.toString(dblCentreNorthing)+")";
strSQL += " * (Northing - " + Double.toString(dblCentreNorthing)+"))";
strSQL += " COLLATE NOCASE";
return myDbHelper.myDataBase.rawQuery(strSQL, null);
}
Doch dies erzeugt ein „SQLiteException: 1. ORDER BY Begriff keine Spalte passen in das Ergebnis setzt "Fehler.
Der vollständige Fehler in LogCat ist:
ERROR/AndroidRuntime(11444): Caused by: android.database.sqlite.SQLiteException: 1st ORDER BY term does not match any column in the result set: , while compiling: SELECT * FROM TableA UNION SELECT * FROM TableB WHERE (Easting > 594378.8427734375 AND Easting < 663822.8427734375 AND Northing > 127586.046875 AND Northing < 197030.046875 AND Name LIKE '%%') ORDER BY ((Easting - 629100.8427734375) * (Easting - 629100.8427734375) + (Northing - 162308.046875) * (Northing - 162308.046875)) COLLATE NOCASE
jemand mich auf dem richtigen Weg helfen kann, bitte?
Sind drei Felder, die Sie in TabelleA oder nur in TabelleB bestellen möchten –
Tabelle A und TabelleB enthalten beide geographisch verwandte Datenelemente ... jede Tabelle hat ein Rechtswert- und ein Neigungsfeld (entspricht weitgehend Längen- und Breitengrad). Die Sortierreihenfolge ist die Entfernung von einem zentralen Punkt, also wird ein berechnetes Feld auf jede Zeile in beiden Tabellen angewendet, indem von jeder Zeile die Ost- und Nordrichtung genommen wird. – prepbgg
Nun, das hängt nicht mit Ihrer Frage zusammen. Aber besser Sie StringBuilder anstelle der String + = String-Operationen. Nur eine gute Praxis (und eine enorme Leistungssteigerung, wenn Sie häufig zu diesen Aktionen in Ihrer App aufgefordert werden) –