ich ohne Erfolg die folgende Methode bin Ausführung beacause der selectArgs nicht mehr korrekt sind (zumindest ist es das, was ich glaube,NULL-Werte in Android Auswählen SQLite
findAll.
public Collection<Object> findAllByCodigoSetorOrderByStatusWhereDataAgendamentoIsNull(Integer vendedor) {
Collection<Object> objects = null;
String selection = Object.FIELDS[20] + "=?" + " OR " + Object.FIELDS[20] + "=?" + " OR " + Object.FIELDS[20] + "=?" + " AND " + Object.FIELDS[6] + "=?";
String[] selectionArgs = new String[] { "''", "'null'", "NULL", String.valueOf(vendedor) };
Collection<ContentValues> results = findAllObjects(Object.TABLE_NAME, selection, selectionArgs, Object.FIELDS, null, null, Object.FIELDS[4]);
objects = new ArrayList<Object>();
for (ContentValues result : results) {
objects.add(new Object(result));
}
return objects;
}
findAllObjects:
protected Collection<ContentValues> findAllObjects(String table, String selection, String[] selectionArgs, String[] columns, String groupBy, String having, String orderBy) {
Cursor cursor = null;
ContentValues contentValue = null;
Collection<ContentValues> contentValues = null;
try {
db = openRead(this.helper);
if (db != null) {
cursor = db.query(table, columns, selection, selectionArgs, groupBy, having, orderBy);
contentValues = new ArrayList<ContentValues>();
for (int i = 0; i < cursor.getCount(); i++) {
cursor.moveToPosition(i);
contentValue = new ContentValues();
for (int c = 0; c < cursor.getColumnCount(); c++) {
contentValue.put(cursor.getColumnName(c), cursor.getString(c));
}
contentValues.add(contentValue);
cursor.moveToNext();
}
}
return contentValues;
} finally {
close(db);
}
}
Wie kann ich auswählen und vergleichen Sie richtig eine Spalte - nul l, 'null' und '' mit der db.query?
gehen Sie mit Ihren Daten mit einem 'Cursor' ? – Cornholio
Bearbeitet, um die Frage klarer zu machen ... Danke für die Frage Cornholio. – MBarni
Der einfachste Weg, um eine Zeile für einen Nullwert zu überprüfen, ist dies - 'if (cursor.isNull (cursor.getColumnIndex (" my_column ")) doStuff();'. Gibt es einen Grund, warum Sie das nicht verwenden können? – Cornholio