Ввод данных в SQLite и их получение

301
02 августа 2017, 19:42

При старте Fragment в 16 его EditText должны загрузиться данные из БД. Далее после закрытия Fragment введенные данные должны быть внесены в БД. При последующих открытиях этого Fragment опять должны загружаться те же данные, но уже с внесенными до этого изменениями. Вопрос: как такое сделать? Ну хотя бы в 4 EditText для начала, а то много писать выйдет.

Вот класс DBHelper:

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DBHelper extends SQLiteOpenHelper{
public static final int DATABASE_VERSION = 1;
public static final String DATABASE_NAME = "FirstDatabase";
public static final String TABLE_RINGS = "rings";
public static final String KEY_ID = "_id";
public static final String KEY_START = "start";
public static final String KEY_END = "end";
public DBHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
    db.execSQL("create table " + TABLE_RINGS + "(" + KEY_ID
            + " integer primary key," + KEY_START + " text," + KEY_END + " text" + ")");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    db.execSQL("drop table if exists " + TABLE_RINGS);
    onCreate(db);
    }
}

Вот фрагмент (выдает ошибку):

import android.app.Fragment;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.EditText;
import android.widget.TextView;

public class FragmentRings extends Fragment {
    DBHelper dbHelper;
    SQLiteDatabase database;
    @Override
    public void onStart() {
        super.onStart();
        dbHelper = new DBHelper(getActivity());
        EditText one = (EditText) getView().findViewById(R.id.oneurok);
        EditText oneee = (EditText) getView().findViewById(R.id.editText2);
        EditText two = (EditText) getView().findViewById(R.id.twourok);
        EditText twooo = (EditText) getView().findViewById(R.id.editText3);
        database = dbHelper.getWritableDatabase();
        Cursor userCursor = database.query(DBHelper.TABLE_RINGS, null, null, null, null, null, null);
        if (userCursor.moveToFirst()) {
        while (!userCursor.isAfterLast()) {
            String data = userCursor.getString(userCursor.getColumnIndex(DBHelper.KEY_START));
            String data1 = userCursor.getString(userCursor.getColumnIndex(DBHelper.KEY_END));
            one.setText(data);
            oneee.setText(data1);
            userCursor.moveToNext();
            String data2 = userCursor.getString(userCursor.getColumnIndex(DBHelper.KEY_START));
            String data3 = userCursor.getString(userCursor.getColumnIndex(DBHelper.KEY_END));
            two.setText(data);
            twooo.setText(data1);
        }
    }
    userCursor.close();

}
    @Override
    public void onStop() {
        database = dbHelper.getWritableDatabase();
        ContentValues contentValues = new ContentValues();
        EditText one = (EditText) getView().findViewById(R.id.oneurok);
        EditText oneee = (EditText) getView().findViewById(R.id.editText2);
        EditText two = (EditText) getView().findViewById(R.id.twourok);
        EditText twooo = (EditText) getView().findViewById(R.id.editText3);
        contentValues.put(DBHelper.KEY_START, one.getText().toString());
        contentValues.put(DBHelper.KEY_END, oneee.getText().toString());
        contentValues.put(DBHelper.KEY_START, two.getText().toString());
        contentValues.put(DBHelper.KEY_END, twooo.getText().toString());
        database.insert(DBHelper.TABLE_RINGS, null, contentValues);
        super.onStop();
    }
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, Bundle savedInstanceState) {
        View RingsView =
            inflater.inflate(R.layout.fragment_rings, container, false);
        return RingsView;
    }
}

Лог ошибки при открытии фрагмента на эмуляторе:

08-01 16:49:24.686 3339-3339/com.churkin.myproject E/AndroidRuntime: FATAL 
EXCEPTION: main
Process: com.churkin.myproject, PID: 3339
android.database.CursorIndexOutOfBoundsException: Index 7 requested, with a 
size of 7
at 
android.database.AbstractCursor.checkPosition(AbstractCursor.java:426)
at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:50)
at 
com.churkin.myproject.FragmentRings.onStart(FragmentRings.java:70)
at 
android.app.Fragment.performStart(Fragment.java:2077)
at 
android.app.FragmentManagerImpl.moveToState(FragmentManager.java:922)
at 
android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1067)
at 
android.app.BackStackRecord.run(BackStackRecord.java:834)
at 
android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1452)
at 
android.app.FragmentManagerImpl$1.run(FragmentManager.java:447)
at 
android.os.Handler.handleCallback(Handler.java:739)
at 
android.os.Handler.dispatchMessage(Handler.java:95)
at 
android.os.Looper.loop(Looper.java:135)
at 
android.app.ActivityThread.main(ActivityThread.java:5254)
at 
java.lang.reflect.Method.invoke(Native Method)
at 
java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
Answer 1

Вот так правильно работать с курсором в вашем случае

Cursor userCursor = database.query(DBHelper.TABLE_RINGS, null, null, null, null, null, null);
if (userCursor != null ) {
  if  (userCursor.moveToFirst()) {
    do {
        // читаем только одну запись, никаких переходов дальше
        String data = userCursor.getString(userCursor.getColumnIndex(DBHelper.KEY_START));
        String data1 = userCursor.getString(userCursor.getColumnIndex(DBHelper.KEY_END));
        // заносим данные в UI
        // ...
    } while (userCursor.moveToNext());
  }
  userCursor.close();
}

Если у вас только две пары контролов, читайте только первые две записи и break из цикла.

READ ALSO
Добавление переменной в SQL через JDBC

Добавление переменной в SQL через JDBC

Подключаюсь к базе c помощью jdbcХотел бы создать в SQL запросе переменную, которую потом можно было бы подставлять в основную логику программы...

319
Не могу отловить баг в коде MainActivity.java

Не могу отловить баг в коде MainActivity.java

Приложение для игры в крестики-нолики написалСделал так чтобы можно было засчитать победу

215
Тextarea проверка на количество [требует правки]

Тextarea проверка на количество [требует правки]

В textarea, при вставке оставить только цифры и поделить их по 10 знаковПосле 10 знаков поставить запятую при этом если число начинается на 7 или...

182