Android SQLite数据库崩溃

时间:2013-08-10 21:20:58

标签: android sqlite

我的数据库中有一个表有问题。 问题是MOVEMENTS表: 每当我插入一些东西它工作正常,但当我尝试检索一个运动我的应用程序崩溃。

我不知道我做错了什么,它与CLIENTS表基本完全相同

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

import java.util.ArrayList;
import java.util.List;

public class DatabaseHandler extends SQLiteOpenHelper {

    private static final int DATABASE_VERSION = 1;

    private static final String DATABASE_NAME = "ClientsManager";

    private static final String CLIENTS_TABLE = "Clients";
    private static final String MOVEMENTS_TABLE = "Movements";

    //Client Table Columns
    private static final String KEY_ROWID = "numint";
    private static final String KEY_NAME = "name";
    private static final String KEY_LOCAL = "locality";
    private static final String KEY_ADDR = "address";
    private static final String KEY_BTTLP = "bottle_price";
    private static final String KEY_PBLNC = "prev_balance";
    private static final String KEY_BLNC = "balance";
    private static final String KEY_BBTTLS = "bonif_bottles";
    private static final String KEY_PBTTLS = "prev_bottles";
    private static final String KEY_BTTLS = "bottles";
    private static final String KEY_SYNC = "sync_date";
    private static final String KEY_MODIF = "modif_date";

    //Movements Table Columns
    private static final String MKEY_ROWID = "numint";
    private static final String MKEY_ID_MOVE = "move_id";
    private static final String MKEY_CLIENT_ID = "client_id";
    private static final String MKEY_PICKUP = "pickup";
    private static final String MKEY_DELIVER = "deliver";
    private static final String MKEY_PAYMENT = "payment";
    private static final String MKEY_MOVE_DATE = "move_date";
    private static final String MKEY_SYNC_DATE = "sync_date";
    private static final String MKEY_FLAG_SYNC = "flag_sync";


    public DatabaseHandler(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        String CREATE_CLIENTS_TABLE = "CREATE TABLE " + CLIENTS_TABLE + "("
                + KEY_ROWID + " INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "
                + KEY_NAME + " TEXT NOT NULL, "
                + KEY_LOCAL + " TEXT NOT NULL, "
                + KEY_ADDR + " TEXT NOT NULL, "
                + KEY_BTTLP + " REAL NOT NULL, "
                + KEY_PBLNC + " REAL NOT NULL, "
                + KEY_BLNC + " REAL NOT NULL, "
                + KEY_BBTTLS + " INTEGER NOT NULL, "
                + KEY_PBTTLS + " INTEGER NOT NULL, "
                + KEY_BTTLS + " INTEGER NOT NULL, "
                + KEY_SYNC + " TEXT NOT NULL, "
                + KEY_MODIF + " TEXT NOT NULL )";

        String CREATE_MOVEMENTS_TABLE = "CREATE TABLE " + MOVEMENTS_TABLE + "("
                + MKEY_ROWID + " INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "
                + MKEY_ID_MOVE + " TEXT NOT NULL, "
                + MKEY_CLIENT_ID + " INTEGER NOT NULL, "
                + MKEY_PICKUP + " INTEGER NOT NULL, "
                + MKEY_DELIVER + " INTEGER NOT NULL, "
                + MKEY_PAYMENT + " REAL NOT NULL, "
                + MKEY_MOVE_DATE + " TEXT NOT NULL, "
                + MKEY_SYNC_DATE + " TEXT NOT NULL, "
                + MKEY_FLAG_SYNC + " INTEGER NOT NULL )";

        sqLiteDatabase.execSQL(CREATE_CLIENTS_TABLE);
        sqLiteDatabase.execSQL(CREATE_MOVEMENTS_TABLE);
    }

    @Override
    public void onUpgrade(SQLiteDatabase sqLiteDatabase, int oldVersion, int newVersion) {
        sqLiteDatabase.execSQL("DROP TABLE IF EXISTS " + CLIENTS_TABLE);
        sqLiteDatabase.execSQL("DROP TABLE IF EXISTS " + MOVEMENTS_TABLE);
        onCreate(sqLiteDatabase);
    }

    public void addClient(Client client) {
        SQLiteDatabase db = this.getWritableDatabase();

        ContentValues values = new ContentValues();

        values.put(KEY_NAME, client.getName());
        values.put(KEY_LOCAL, client.getLocality());
        values.put(KEY_ADDR, client.getAddress());
        values.put(KEY_BTTLP, client.getBottlePrice());
        values.put(KEY_PBLNC, client.getPrevBalance());
        values.put(KEY_BLNC, client.getBalance());
        values.put(KEY_BBTTLS, client.getBonifBottles());
        values.put(KEY_PBTTLS, client.getPrevBottles());
        values.put(KEY_BTTLS, client.getBottles());
        values.put(KEY_SYNC, client.getSyncDate());
        values.put(KEY_MODIF, client.getModifDate());

        //Insert row
        db.insert(CLIENTS_TABLE, null, values);
        db.close();
    }

    public Client getClient(int id) {
        SQLiteDatabase db = this.getReadableDatabase();

        Cursor cursor = db.query(CLIENTS_TABLE, new String[] { KEY_ROWID, KEY_NAME, KEY_LOCAL,
                KEY_ADDR, KEY_BTTLP, KEY_PBLNC, KEY_BLNC, KEY_BBTTLS, KEY_PBTTLS, KEY_BTTLS, KEY_SYNC, KEY_MODIF}, KEY_ROWID + "=?",
                new String[] {String.valueOf(id)}, null, null, null, null);

        if(cursor != null) {
            cursor.moveToFirst();
        }

        Client client = new Client(Integer.parseInt(cursor.getString(0)), cursor.getString(1), cursor.getString(2),
                cursor.getString(3), Float.parseFloat(cursor.getString(4)), Float.parseFloat(cursor.getString(5)),
                Float.parseFloat(cursor.getString(6)), Integer.parseInt(cursor.getString(7)), Integer.parseInt(cursor.getString(8)),
                Integer.parseInt(cursor.getString(9)), cursor.getString(10), cursor.getString(11));

        return client;
    }

    public List<Client> getAllClients() {
        List<Client> clientList = new ArrayList<Client>();

        String selectQuery = "SELECT * FROM " + CLIENTS_TABLE;

        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);

        if(cursor.moveToFirst()) {
            do {

                Client client = new Client(Integer.parseInt(cursor.getString(0)), cursor.getString(1), cursor.getString(2),
                        cursor.getString(3), Float.parseFloat(cursor.getString(4)), Float.parseFloat(cursor.getString(5)),
                        Float.parseFloat(cursor.getString(6)), Integer.parseInt(cursor.getString(7)), Integer.parseInt(cursor.getString(8)),
                        Integer.parseInt(cursor.getString(9)), cursor.getString(10), cursor.getString(11));

                clientList.add(client);

            }while(cursor.moveToNext());
        }

        return clientList;
    }

    public int getClientCount() {
        String countQuery = "SELECT * FROM " + CLIENTS_TABLE;
        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(countQuery, null);
        cursor.close();

        return cursor.getCount();
    }

    public int updateClient(Client client) {

        SQLiteDatabase db = this.getWritableDatabase();

        ContentValues values = new ContentValues();
        values.put(KEY_PBLNC, client.getPrevBalance());
        values.put(KEY_BLNC, client.getBalance());
        values.put(KEY_PBTTLS, client.getPrevBottles());
        values.put(KEY_BTTLS, client.getBottles());
        values.put(KEY_MODIF, client.getModifDate());

        return db.update(CLIENTS_TABLE, values, KEY_ROWID + "=?",
                new String[] {String.valueOf(client.getId())});
    }

    public int deleteClient(Client client) {
        int count = 0;
        SQLiteDatabase db = this.getWritableDatabase();
        count = db.delete(CLIENTS_TABLE, KEY_ROWID + "=?", new String[] {String.valueOf(client.getId())});
        db.close();

        return count;
    }

    public int deleteAllClients() {
        List<Client> clientList = getAllClients();
        SQLiteDatabase db = this.getWritableDatabase();
        int count = 0;
        for(int i = 0; i < clientList.size(); i++) {
            count += db.delete(CLIENTS_TABLE, KEY_ROWID + "=?", new String[] {String.valueOf(clientList.get(i).getId())});
        }

        return  count;
    }

    public void addMovement(Movement movement) {

        SQLiteDatabase db = this.getWritableDatabase();

        ContentValues values = new ContentValues();
        values.put(MKEY_ID_MOVE, movement.getMoveId());
        values.put(MKEY_CLIENT_ID, movement.getClientId());
        values.put(MKEY_PICKUP, movement.getPickUp());
        values.put(MKEY_DELIVER, movement.getDeliver());
        values.put(MKEY_PAYMENT, movement.getPayment());
        values.put(MKEY_MOVE_DATE, movement.getMoveDate());
        values.put(MKEY_SYNC_DATE, movement.getSyncDate());
        values.put(MKEY_FLAG_SYNC, movement.getFlagSync());

        db.insert(MOVEMENTS_TABLE, null, values);
        db.close();
    }

    public Movement getMovement(int clientId) {
        SQLiteDatabase db = this.getReadableDatabase();

        Cursor cursor = db.query(MOVEMENTS_TABLE, new String[] {MKEY_ROWID, MKEY_ID_MOVE, MKEY_CLIENT_ID,
        MKEY_PICKUP, MKEY_DELIVER, MKEY_PAYMENT, MKEY_MOVE_DATE, MKEY_SYNC_DATE, MKEY_SYNC_DATE}, MKEY_CLIENT_ID + "=?",
                 new String[] {String.valueOf(clientId)}, null, null, null, null);

        Movement movement = null;

        if(cursor != null) {
            if(cursor.moveToFirst()) {
                movement = new Movement(Integer.parseInt(cursor.getString(0)), cursor.getString(1), Integer.parseInt(cursor.getString(2)),
                        Integer.parseInt(cursor.getString(3)), Integer.parseInt(cursor.getString(4)), Float.parseFloat(cursor.getString(5)),
                        cursor.getString(6), cursor.getString(7), Integer.parseInt(cursor.getString(8)));
            }
        }

        return movement;
    }

    public List<Movement> getAllMovements() {
        List<Movement> movementList = new ArrayList<Movement>();

        String query = "SELECT * FROM " + MOVEMENTS_TABLE;

        SQLiteDatabase db = this.getReadableDatabase();

        Cursor cursor = db.rawQuery(query, null);

        if(cursor.moveToFirst()) {
            do {

                Movement movement = new Movement(Integer.parseInt(cursor.getString(0)), cursor.getString(1), Integer.parseInt(cursor.getString(2)),
                        Integer.parseInt(cursor.getString(3)), Integer.parseInt(cursor.getString(4)), Float.parseFloat(cursor.getString(5)),
                        cursor.getString(6), cursor.getString(7), Integer.parseInt(cursor.getString(8)));

                movementList.add(movement);

            }while (cursor.moveToNext());
        }

        return movementList;
    }

    public int deleteAllMovements() {
        SQLiteDatabase db = this.getWritableDatabase();
        List<Movement> movementList = getAllMovements();

        int count = 0;

        for(int i = 0; i < movementList.size(); i++) {
            count += db.delete(MOVEMENTS_TABLE, MKEY_ROWID + "=?", new String[] {String.valueOf(movementList.get(i).getId())});
        }

        return count;
    }

    public int updateMovement(Movement movement) {
        SQLiteDatabase db = this.getWritableDatabase();

        ContentValues values = new ContentValues();
        values.put(MKEY_PICKUP, movement.getPickUp());
        values.put(MKEY_DELIVER, movement.getDeliver());
        values.put(MKEY_PAYMENT, movement.getPayment());
        values.put(MKEY_MOVE_DATE, movement.getMoveDate());

        return db.update(MOVEMENTS_TABLE, values, MKEY_ROWID + "=?", new String[] {String.valueOf(movement.getId())});

    }

}

1 个答案:

答案 0 :(得分:0)

我通过使用Cursor方法解决了这个问题:getInt()和getFloat()而不是解析getString()的结果

现在该应用程序正常运行