AS Room編④ ~Roomを使って、登録したデータを別のAcitivityに表示する~

EditTextに、名前を入力し、登録ボタンを押すとデータベースに登録される。

一覧表示ボタンを押すと、別のActivityでデータ一覧を確認できる。上下にスクロールできるようにしている。

EditTextに、データにある名前を入力し、削除ボタンを押すとデータベースから、そのデータが削除される。

 

MainActivity.java

package com.example.room5;

import androidx.appcompat.app.AppCompatActivity;
import androidx.room.Dao;

import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

import com.google.android.material.snackbar.Snackbar;

import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {
static AppDatabase db;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

TextView showData = findViewById(R.id.showData);

Button registerBtn = findViewById(R.id.registerBtn);
db = AppDatabaseSingleton.getInstance(getApplicationContext());
registerBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
new Thread(new Runnable(){

@Override
public void run() {
// 本質的な処理
UserDao userDao = db.userDao();
EditText editName = findViewById(R.id.editName);
userDao.insert(new User(editName.getText().toString()));
}
}).start();

Snackbar.make(MainActivity.this,view,"1件のデータが登録されました。",Snackbar.LENGTH_LONG).show();

}
});


Button deleteBtn = findViewById(R.id.deleteBtn);
deleteBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
new Thread(new Runnable(){

@Override
public void run() {
// 本質的な処理
UserDao userDao = db.userDao();
EditText editName = findViewById(R.id.editName);
List<User> filterList = userDao.selectByUserName(editName.getText().toString());
for(int i=0;i<filterList.size();i++){
userDao.delete(filterList.get(i));
}
}
}).start();

Snackbar.make(MainActivity.this,view,"1件のデータが削除されました。",Snackbar.LENGTH_LONG).show();

}
});

Button displayBtn = findViewById(R.id.displayBtn);
displayBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
startActivity(new Intent(MainActivity.this,SecondActivity.class));
}
});

}

}

SecondActivity.java

package com.example.room5;

import static com.example.room5.MainActivity.db;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;

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

public class SecondActivity extends AppCompatActivity {


@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);

TextView secondView = findViewById(R.id.secondView);

//Handler
Handler handler = new Handler(){
public void handleMessage(Message msg){
StringBuilder recievedStrBld =(StringBuilder) msg.obj;
secondView.setText(recievedStrBld.toString());
}

};


new Thread(new Runnable(){
@Override
public void run() {
// 本質的な処理
UserDao userDao = db.userDao();
List<User> atList = userDao.getAll();
StringBuilder sb = new StringBuilder();
for(User user:atList){
sb.append(user.getName()).append("\n");
}

Message msg = new Message();
msg.obj = sb;

handler.sendMessage(msg);
}
}).start();
}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:gravity="center_horizontal"
android:orientation="vertical">

<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="名前:"/>
<EditText
android:id="@+id/editName"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
<Button
android:id="@+id/registerBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="登録"/>
<Button
android:id="@+id/deleteBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="削除"/>
<TextView
android:id="@+id/showData"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>

<Button
android:id="@+id/displayBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="一覧表示"/>

</LinearLayout>

activity_second.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".SecondActivity">

<ScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/secondView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="40sp"/>
</ScrollView>
</LinearLayout>

AppDatabase.java

package com.example.room5;

import androidx.room.Database;
import androidx.room.RoomDatabase;

@Database(entities = {User.class},version = 1,exportSchema = false)
public abstract class AppDatabase extends RoomDatabase {
public abstract UserDao userDao();
}

AppDatabaseSingleton.java

package com.example.room5;

import android.content.Context;

import androidx.room.Room;

public class AppDatabaseSingleton {
private static AppDatabase instance = null;

static AppDatabase getInstance(Context context){
instance = Room.databaseBuilder(context,AppDatabase.class,"dtabase-app").build();
return instance;
}
}

User.java

package com.example.room5;

import androidx.annotation.NonNull;
import androidx.room.ColumnInfo;
import androidx.room.Entity;
import androidx.room.PrimaryKey;

@Entity(tableName ="users")
public class User {
@PrimaryKey(autoGenerate = true)
@NonNull
@ColumnInfo(name = "id")
private int id;

@ColumnInfo(name = "name")
private String name;

public User(String name) {
this.name = name;
}

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}
}

UserDao(インターフェース)

package com.example.room5;

import androidx.room.Dao;
import androidx.room.Delete;
import androidx.room.Insert;
import androidx.room.Query;

import java.util.List;

@Dao
public interface UserDao {
@Insert
void insertAll(User... users);

@Insert
void insert(User user);

@Delete
void delete(User user);

@Query("SELECT * FROM users")
List<User> getAll();

@Query("SELECT * FROM users where name IN(:username)")
List<User> selectByUserName(String username);
}