Android java sqlite insert
Продолжим работу с проектом из прошлой темы, где мы получаем данные. Теперь добавим в него стандартную CRUD-логику (создание, обновление, удаление).
Чтобы не нагромождать форму с главной activity, все остальные действия по работе с данными будут происходить на другом экране. Добавим в проект новый класс activity, который назовем UserActivity:
В файле activity_user.xml определим универсальую форму для добавления/обновления/удаления данных:
И также изменим код UserActivity :
package com.example.sqliteapp; import androidx.appcompat.app.AppCompatActivity; import android.content.ContentValues; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.EditText; public class UserActivity extends AppCompatActivity < EditText nameBox; EditText yearBox; Button delButton; Button saveButton; DatabaseHelper sqlHelper; SQLiteDatabase db; Cursor userCursor; long userId=0; @Override protected void onCreate(Bundle savedInstanceState) < super.onCreate(savedInstanceState); setContentView(R.layout.activity_user); nameBox = findViewById(R.id.name); yearBox = findViewById(R.id.year); delButton = findViewById(R.id.deleteButton); saveButton = findViewById(R.id.saveButton); sqlHelper = new DatabaseHelper(this); db = sqlHelper.getWritableDatabase(); Bundle extras = getIntent().getExtras(); if (extras != null) < userId = extras.getLong("id"); >// если 0, то добавление if (userId > 0) < // получаем элемент по id из бд userCursor = db.rawQuery("select * from " + DatabaseHelper.TABLE + " where " + DatabaseHelper.COLUMN_ID + "=?", new String[]); userCursor.moveToFirst(); nameBox.setText(userCursor.getString(1)); yearBox.setText(String.valueOf(userCursor.getInt(2))); userCursor.close(); > else < // скрываем кнопку удаления delButton.setVisibility(View.GONE); >> public void save(View view) < ContentValues cv = new ContentValues(); cv.put(DatabaseHelper.COLUMN_NAME, nameBox.getText().toString()); cv.put(DatabaseHelper.COLUMN_YEAR, Integer.parseInt(yearBox.getText().toString())); if (userId >0) < db.update(DatabaseHelper.TABLE, cv, DatabaseHelper.COLUMN_ID + "=" + userId, null); >else < db.insert(DatabaseHelper.TABLE, null, cv); >goHome(); > public void delete(View view)< db.delete(DatabaseHelper.TABLE, "_id = ?", new String[]); goHome(); > private void goHome() < // закрываем подключение db.close(); // переход к главной activity Intent intent = new Intent(this, MainActivity.class); intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP); startActivity(intent); >>
При обновлении или удалении объекта из списка из главной activity в UserActivity будет передаваться id объекта:
long userId=0; //. Bundle extras = getIntent().getExtras(); if (extras != null)
Если из MainActivity не было передано id, то устанавливаем его значение 0, следовательно, у нас будет добавление, а не редактирование/удаление
Если id определен, то получаем по нему из базы данных объект для редактирования/удаления:
if (id < 0) < userCursor = db.rawQuery("select * from " + DatabaseHelper.TABLE + " where " + DatabaseHelper.COLUMN_ID + "=?", new String[]); userCursor.moveToFirst(); nameBox.setText(userCursor.getString(1)); yearBox.setText(String.valueOf(userCursor.getInt(2))); userCursor.close(); >
Иначе просто скрываем кнопку удаления.
Для выполнения операций по вставке, обновлению и удалению данных SQLiteDatabase имеет методы insert() , update() и delete() . Эти методы вызываются в обработчиках кнопок:
db.delete(DatabaseHelper.TABLE, "_id = ?", new String[]);
В метод delete() передается название таблицы, а также столбец, по которому происходит удаление, и его значение. В качестве критерия можно выбрать несколько столбцов, поэтому третьим параметром идет массив. Знак вопроса ? обозначает параметр, вместо которого подставляется значение из третьего параметра.
ContentValues
Для добавления или обновления нам надо создать объект ContentValues . Данный объект представляет словарь, который содержит набор пар «ключ-значение». Для добавления в этот словарь нового объекта применяется метод put . Первый параметр метода — это ключ, а второй — значение, например:
ContentValues cv = new ContentValues(); cv.put("NAME", "Tom"); cv.put("YEAR", 30);
В качестве значений в метод put можно передавать строки, целые числа, числа с плавающей точкой
В данном же случае добавляются введенные в текстовое поля значения:
ContentValues cv = new ContentValues(); cv.put(DatabaseHelper.COLUMN_NAME, nameBox.getText().toString()); cv.put(DatabaseHelper.COLUMN_YEAR, Integer.parseInt(yearBox.getText().toString()));
При обновлении в метод update() передается название таблицы, объект ContentValues и критерий, по которому происходит обновление (в данном случае столбец id):
db.update(DatabaseHelper.TABLE, cv, DatabaseHelper.COLUMN_ID + " brush:java;">db.insert(DatabaseHelper.TABLE, null, cv);
Вместо этих методов, как в прошлой теме, можно использовать метод execSQL() с точным указанием выполняемого sql-выражения. В то же время методы delete/insert/update имеют преимущество — они возвращают id измененной записи, по которому мы можем узнать об успешности операции, или -1 в случае неудачной операции:
long result = db.insert(DatabaseHelper.TABLE, null, cv); if(result>0) < // действия >
После каждой операции выполняется метод goHome() , который возвращает на главную activity.
После этого нам надо исправить код MainActivity, чтобы она инициировала выполнение кода в UserActivity. Для этого изменим код activity_main.xml :
В данном случае была добавлена кнопка для вызова UserActivity.
И также изменим код класса MainActivity :
package com.example.sqliteapp; import androidx.appcompat.app.AppCompatActivity; import android.content.Intent; import android.view.View; import android.widget.AdapterView; import android.widget.SimpleCursorAdapter; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.widget.ListView; public class MainActivity extends AppCompatActivity < ListView userList; DatabaseHelper databaseHelper; SQLiteDatabase db; Cursor userCursor; SimpleCursorAdapter userAdapter; @Override protected void onCreate(Bundle savedInstanceState) < super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); userList = findViewById(R.id.list); userList.setOnItemClickListener(new AdapterView.OnItemClickListener() < @Override public void onItemClick(AdapterViewparent, View view, int position, long id) < Intent intent = new Intent(getApplicationContext(), UserActivity.class); intent.putExtra("id", id); startActivity(intent); >>); databaseHelper = new DatabaseHelper(getApplicationContext()); > @Override public void onResume() < super.onResume(); // открываем подключение db = databaseHelper.getReadableDatabase(); //получаем данные из бд в виде курсора userCursor = db.rawQuery("select * from " + DatabaseHelper.TABLE, null); // определяем, какие столбцы из курсора будут выводиться в ListView String[] headers = new String[]; // создаем адаптер, передаем в него курсор userAdapter = new SimpleCursorAdapter(this, android.R.layout.two_line_list_item, userCursor, headers, new int[], 0); userList.setAdapter(userAdapter); > // по нажатию на кнопку запускаем UserActivity для добавления данных public void add(View view) < Intent intent = new Intent(this, UserActivity.class); startActivity(intent); >@Override public void onDestroy() < super.onDestroy(); // Закрываем подключение и курсор db.close(); userCursor.close(); >>
При нажатии на кнопку запускается UserActivity, при этом не передается никакого id, то есть в UserActivity id будет равен нулю, значит будет идти добавление данных:
Другую ситуацию представляет обработчик нажатия на элемент списка — при нажатии также будет запускаться UserActivity, но теперь будет передаваться id выбранной записи:
public void onItemClick(AdapterView parent, View view, int position, long id)
Запустим приложение и нажмем на кнопку, которая должен перенаправлять на UserActivity:
При нажатии в MainActivity на элемент списка этот элемент попадет на UserActivity, где его можно будет удалить или подредактировать: