Курсор, возвращающий неверные значения - PullRequest
1 голос
/ 19 августа 2011

Я создаю приложение для мониторинга личных финансов.Пользователь создает учетные записи, категории и транзакции.Класс dBHelper.java создает базу данных, как показано ниже:

public void onCreate(SQLiteDatabase db) {
    //executes only once
    //create tables
    Log.v("TAG", "creating table:" +racuniTable);
    String sql = "create table " +racuniTable+" (" +colID+ " INTEGER PRIMARY KEY AUTOINCREMENT, " 
    +colName+ " TEXT, " +colValue+ " REAL, " +colAccType+ " TEXT);";

    Log.v("TAG", "creating table:" +transakcijeTable);
    String sql1 = "create table " +transakcijeTable+" (" +colTransID+ " INTEGER PRIMARY KEY AUTOINCREMENT, " 
    +colTransDate+ " DATE, "  +colAmount+ " REAL, " 
    +colIDracuni+ " INTEGER, " +colIDkategorije+ " INTEGER);";

    Log.v("TAG", "creating table:" +kategorijeTable);
    String sql2 = "create table " +kategorijeTable+" (" +colCatID+ " INTEGER PRIMARY KEY AUTOINCREMENT, " +colCatName+ " TEXT);";
    Log.v("TAG", "adding account:");

    db.execSQL(sql);
    db.execSQL(sql1);
    db.execSQL(sql2);
}

Эта функция создает три базы данных.Проблема возникает, когда я пытаюсь получить список всех транзакций или любой другой отчет, настроенный предложением SQL:

private void getTransactions(){

    try {
        DbHelper dbHelper = new DbHelper(this.getApplicationContext());
        newDB = dbHelper.getWritableDatabase(); 
        m_transaction = new ArrayList<transaction>();
        Cursor c = newDB.rawQuery("SELECT rac.Ime, trans.Znesek, trans.Datum,   kate.Ime FROM Racuni AS rac, " + "Transakcije AS trans, Kategorije 
        as kate WHERE trans.ID_racuna=rac._id AND trans.ID_kategorije=kate._id", null);

        if (c != null ) {
            if  (c.moveToFirst()) {
                do {
                    String racun = c.getString(c.getColumnIndex("rac.Ime"));
                    double znesek = c.getDouble(c.getColumnIndex("trans.Znesek"));
                    String datum = c.getString(c.getColumnIndex("trans.Datum"));
                    String kategorija = c.getString(c.getColumnIndex("kate.Ime"));

                    transaction t1 = new transaction();
                    t1.setracun(racun);
                    t1.setznesek(znesek);
                    t1.setdatum(datum);
                    t1.setkategorija(kategorija);   

                    m_transaction.add(t1);

                }while (c.moveToNext());
            }
        }       
    } catch (SQLiteException se ) {
    Log.e(getClass().getSimpleName(), "Could not create or Open the database");
  }

Я использовал Cursor, чтобы показать список счетов раньше, и он работал отлично,Я не знаю, почему это больше не работает.Я не использовал внешние ключи в таблицах или что-то подобное, и это должно работать.Если я выполню код, я получу неправильные значения и множество ошибок.Я получаю ошибки в этих конкретных строках:

String racun = c.getString(c.getColumnIndex("rac.Ime"));
double znesek = c.getDouble(c.getColumnIndex("trans.Znesek"));
String datum = c.getString(c.getColumnIndex("trans.Datum"));
String kategorija = c.getString(c.getColumnIndex("kate.Ime"));

Приложение запустится, и я напечатаю информацию.Вся напечатанная информация верна.Строка racun такая же, как строка kategorija, когда их не должно быть.Я не уверен, почему я получаю неправильные значения из столбца racun.Я проверил свой SQL, используя SQLite 3 с оболочкой adb, и он работал нормально.Вот ошибки из LogCat:

08-19 17:48:16.279: ERROR/Cursor(625): requesting column name with table name -- rac.Ime

08-19 17:48:16.331: ERROR/Cursor(625): requesting column name with table name -- trans.Znesek

08-19 17:48:16.359: ERROR/Cursor(625): requesting column name with table name -- trans.Datum

08-19 17:48:16.439: ERROR/Cursor(625): requesting column name with table name -- kate.Ime

Что-то не так, потому что я использовал псевдоним в SQL?Это должно быть напечатано:

SELECT rac.Ime, trans.Znesek, trans.Datum, kate.Ime FROM Racuni AS rac, Transakcije AS trans, Kategorije as kate WHERE trans.ID_racuna=rac._id AND trans.ID_kate
    gorije=kate._id;
    Tomaz|50.0|3911-08-18|placa
    Tom|33.0|3912-07-18|placa
    Tomaz|70.0|3800-07-17|zapravlanje
    Tom|69.0|2010-07-17|placa
    Tomaz|30.0|2011-08-18|placa
    Tom|30.0|2011-08-12|zapravlanje
    Tom|50.0|2011-08-01|placa
    sqlite>

Это , остальное я получил.Любые предложения, как решить эту проблему?

Ответы [ 2 ]

2 голосов
/ 19 августа 2011

Изменить

SELECT rac.Ime, trans.Znesek, trans.Datum, kate.Ime FROM ...

на:

SELECT rac.Ime racun, trans.Znesek, trans.Datum, kate.Ime kategorja FROM ...

и затем изменить соответственно

c.getColumnIndex(...)
0 голосов
/ 07 ноября 2016

Пример:

Таблица_1: идентификатор, имя, данные

Таблица_2: идентификатор, имя, цена

String ALL_COLUMNS_TABLE_2="Table_2.id _id, Table_2.name _name, Table_2.price _price";

Cursor cursor = db.rawQuery("select "+ Table_1 +".*,"+ALL_COLUMNS_TABLE_2+" from " + Table_1 + "," + Table_2,null);
try {
            if (cursor.moveToFirst()) {
                while (cursor.isAfterLast() == false) {

                    int idTable1 = cursor.getInt(cursor
                            .getColumnIndex("id"));
int idTable2 = cursor.getInt(cursor
                            .getColumnIndex("_id"));
....
}
...