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);
}