Ошибка базы данных Kotlin CursorIndexOutOfBoundsException

Это ошибка, она говорит индекс за пределами, но я не мог, как я могу его решить, есть некоторые турецкие слова, но они не важны, я думаю:

E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.burhanozen.nothesaplama, PID: 26919 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.burhanozen.nothesaplama/com.example.burhanozen.nothesaplama.MainActivity}: android.database.CursorIndexOutOfBoundsException: Index 1 requested, with a size of 1 at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2665) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2726) at ........ 

Я пытался хранить какую-то информацию о студентах. У меня эти ошибки, и я разделяю коды ниже. Это моя MainActivity:

 override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val toolbar = findViewById(R.id.toolbar) as Toolbar setSupportActionBar(toolbar) val fab = findViewById(R.id.fab) as FloatingActionButton fab.setOnClickListener { val intent = Intent(this@MainActivity,NotEkrani::class.java) startActivity(intent) } val studentsArray = ArrayList<String>() val arrayAdapter = ArrayAdapter(this,android.R.layout.simple_list_item_1,studentsArray) listView.adapter= arrayAdapter try{ val myDatabase = this.openOrCreateDatabase("student", Context.MODE_PRIVATE,null) myDatabase.execSQL("CREATE TABLE IF NOT EXISTS students (isim TEXT," + " dersbir TEXT, dersbirkredi TEXT, dersbirort TEXT," + " dersiki TEXT, dersikikredi TEXT, dersikiort TEXT) ") val cursor = myDatabase.rawQuery("select * from students",null) val nameIx = cursor.getColumnIndex("isim") val dersbirIx = cursor.getColumnIndex("dersbir") val dersbirkrediIx = cursor.getColumnIndex("dersbirkredi") val dersbirortIx = cursor.getColumnIndex("dersbirort") val dersikiIx = cursor.getColumnIndex("dersiki") val dersikikrediIx = cursor.getColumnIndex("dersikikredi") val dersikiortIx = cursor.getColumnIndex("dersikiort") cursor.moveToNext() while (cursor != null){ studentsArray.add(cursor.getString(nameIx)) studentsArray.add(cursor.getString(dersbirIx)) studentsArray.add(cursor.getString(dersbirkrediIx)) studentsArray.add(cursor.getString(dersbirortIx)) studentsArray.add(cursor.getString(dersikiIx)) studentsArray.add(cursor.getString(dersikikrediIx)) studentsArray.add(cursor.getString(dersikiortIx)) cursor.moveToNext() arrayAdapter.notifyDataSetChanged() } while (cursor!=null){ cursor!!.close() } }catch (e:SQLException){ } 

И это моя вторая страница активности, я не мог ошибаться здесь, но может быть, это может помочь. Здесь я написал коды базы данных.

 fun kaydet(view:View){ val isim = isim.text.toString() val dersbir = dersbir.text.toString() val dersbirkredi = dersbirkredi.text.toString() val dersbirort = dersbirort.text.toString() val dersiki = dersiki.text.toString() val dersikikredi = dersikikredi.text.toString() val dersikiort = dersikiort.text.toString() try { val myDatabase = openOrCreateDatabase("student", Context.MODE_PRIVATE,null) myDatabase.execSQL("CREATE TABLE IF NOT EXISTS students (isim TEXT," + " dersbir TEXT, dersbirkredi TEXT, dersbirort TEXT," + " dersiki TEXT, dersikikredi TEXT, dersikiort TEXT) ") val sqlString = "INSERT INTO students (isim,dersbir,dersbirkredi,dersbirort,dersiki,dersikikredi,dersikiort) VALUES(?,?,?,?,?,?,?)" val statement = myDatabase.compileStatement(sqlString) statement.bindString(1,isim) statement.bindString(2,dersbir) statement.bindString(3,dersbirkredi) statement.bindString(4,dersbirort) statement.bindString(5,dersiki) statement.bindString(6,dersikikredi) statement.bindString(7,dersikiort) statement.execute() }catch (e:SQLException){ } val intent = Intent(this,MainActivity::class.java) startActivity(intent) } 

Измените цикл while таким образом:

  while (cursor.moveToNext()){ studentsArray.add(cursor.getString(nameIx)) ... } 

(Удалите все остальные cursor.moveToNext() из вашего кода)

Вы проверяете cursor != null в своем цикле while, но он не станет нулевым после того, как вы прочитаете все строки из курсора.

В приведенном выше коде cursor.moveToNext возвращает true, если следующая строка. В противном случае возвращает false, и цикл завершается.

И, только что заметили, вы должны изменить это,

 while (cursor!=null){ cursor!!.close() } 

в случае проверки:

 if (cursor!=null){ cursor.close() } 

Или, как предложил Тодд в комментариях, вы можете использовать функцию функции более высокого порядка, которая автоматически закрывает курсор, что аналогично Java 7 try-with-resources.

 cursor.use { while (cursor.moveToNext()){ studentsArray.add(cursor.getString(nameIx)) ... } } 

Вы получаете эту ошибку, потому что ваш размер курсора равен 1. В вашей базе данных есть только одна запись. Но вы запрашиваете базу данных более одного раза. Это и есть причина вашей ошибки.

Прежде всего, ваш полный код исполнения неверен.

Вы создаете базу данных в своей деятельности. Если вы это сделаете, вы не сможете эффективно и эффективно управлять своей базой данных.

Во-первых, вам нужно создать базу данных SqliteOpenHelper в отдельном классе. Тогда вам нужно создать таблицу. Затем напишите вспомогательные методы, чтобы получить и вставить в него значения.

Ваш класс базы данных должен быть похож на приведенный ниже пример.

 class DbHelper(context: Context) : SQLiteOpenHelper(context, "example.db", null, 4) { val TAG = javaClass<DbHelper>().getSimpleName() val TABLE = "logs" companion object { public val ID: String = "_id" public val TIMESTAMP: String = "TIMESTAMP" public val TEXT: String = "TEXT" } val DATABASE_CREATE = "CREATE TABLE if not exists " + TABLE + " (" + "${ID} integer PRIMARY KEY autoincrement," + "${TIMESTAMP} integer," + "${TEXT} text"+ ")" fun log(text: String) { val values = ContentValues() values.put(TEXT, text) values.put(TIMESTAMP, System.currentTimeMillis()) getWritableDatabase().insert(TABLE, null, values); } fun getLogs() : Cursor { return getReadableDatabase() .query(TABLE, arrayOf(ID, TIMESTAMP, TEXT), null, null, null, null, null); } override fun onCreate(db: SQLiteDatabase) { Log.d(TAG, "Creating: " + DATABASE_CREATE); db.execSQL(DATABASE_CREATE) } override fun onUpgrade(p0: SQLiteDatabase, p1: Int, p2: Int) { } } 

Поскольку вы используете базу данных Kotin очень легко с Anko-Sqlite . Эта библиотека позволяет хранить и извлекать данные из базы данных. Вы можете проверить это здесь. https://github.com/Kotlin/anko/wiki/Anko-SQLite#using-anko-sqlite-in-your-project

Intereting Posts
Класс не найден, пустой набор тестов в androidTest с использованием Android Studio 3.0.1, Room, Kotlin Андроид anko предупреждение пользовательский макет currentFocus Правильное выполнение ожидания и уведомления в Kotlin Обеспечение инициализации val в Котлине Карта в Firebase onDataChange в Котлине Дженерики для RecyclerView.Adapter Android Kotlin Closable и SQLiteDatabase на Android Запрос андроидов КонтактыКонтракт в Котлине Как создать экземпляр анонимного класса, который реализует интерфейс в Kotlin Как преобразовать кодировку win1251 в UTF8 внутри Kotlin? Расширенное назначение и приращение не поддерживаются для локальных делегированных свойств и встроенных свойств Как объяснить это странное поведение при программном задании полей для представления внутри RelativeLayout? Внедрение исключения Kotlin NullPointer Kotlin: Можете ли вы использовать именованные аргументы для varargs? как ввести «->» в Android Studio