Java 如何在Android的ListView中显示来自SQLite数据库的多个数据

Java 如何在Android的ListView中显示来自SQLite数据库的多个数据,java,android,android-studio,android-listview,Java,Android,Android Studio,Android Listview,我是Android开发的新手 我不知道如何让Android Studio只获取SQLite数据库中的内容并将其内容粘贴到listview中。我原以为在记录输出后会有一种简单的方法,但可以在ListView中显示数据库中的所有内容,但它似乎更多地是以一种不同的方式进行的 public class MainActivity extends AppCompatActivity { EditText nameEditText; EditText phoneEditText;

我是Android开发的新手

我不知道如何让Android Studio只获取SQLite数据库中的内容并将其内容粘贴到listview中。我原以为在记录输出后会有一种简单的方法,但可以在ListView中显示数据库中的所有内容,但它似乎更多地是以一种不同的方式进行的

    public class MainActivity extends AppCompatActivity {

    EditText nameEditText;
    EditText phoneEditText;
    ListView updateListView;

    SQLiteDatabase sqLiteDatabase;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        nameEditText = findViewById(R.id.nameEditText);
        phoneEditText = findViewById(R.id.phoneEditText);
        updateListView = findViewById(R.id.updatedListView);



        sqLiteDatabase = this.openOrCreateDatabase("Contact", MODE_PRIVATE, null);

        sqLiteDatabase.execSQL("CREATE TABLE IF NOT EXISTS users(name VARCHAR, phone INT(11),id INTEGER PRIMARY KEY)");


    }


    public void OnClick(View view) {


        if (nameEditText.equals("") || phoneEditText.equals("")) {
            Toast.makeText(this, "Fields shouldn't be empty", Toast.LENGTH_SHORT).show();
        } else {

            sqLiteDatabase.execSQL("INSERT INTO users(name, phone) VALUES('" + nameEditText.getText().toString() + "','" + phoneEditText.getText().toString() + "')");

            Cursor c = sqLiteDatabase.rawQuery("SELECT * FROM users", null);
            int nameIndex = c.getColumnIndex("name");
            int phoneIndex = c.getColumnIndex("phone");
            int idIndex = c.getColumnIndex("id");
            if (c != null && c.getCount() > 0) {
                c.moveToFirst();
                for (int i = 0; i < c.getCount(); i++) {
                    String str = c.getString(0);

                    String UpdatedList = (c.getString(nameIndex));
                    String phonelist = (c.getString(phoneIndex));

                    String list = (UpdatedList+phonelist);
                    ArrayList<String> arrayList = new ArrayList<String>(Integer.parseInt(list));
                    ArrayAdapter<String> arrayAdapter = new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,arrayList);
                    updateListView.setAdapter(arrayAdapter);              


                    Log.i("User Name", c.getString(nameIndex));
                    Log.i("userResults - age", Integer.toString(c.getInt(phoneIndex)));
                    Log.i("userResults - id", Integer.toString(c.getInt(idIndex)));
                    c.moveToNext();
                }




            }
        }
    }
    }

在从sql声明整个arrayList之后,在for循环外部调用setAdapter方法

是否可以更详细地指定问题/查询??首先
nameEditText.equals(“”
检查空edittext的错误方法,请改为
nameEditText.getText().toString().trim().equals(“”)
尝试在此处发布您的activity\u main.xml,错误为无法执行按钮的onClick函数,最好为您的sqlite事务创建一个数据库帮助器类。Madonabulia:我们鼓励这里的帮助者在答案中写下不止一句话。很短的贡献作为评论更好(如果你喜欢短贡献,你只需要50点声誉就可以做到这一点)。非常简短或不清楚的答案有时会被审查队列删除。@Shivas:尽管我向Madonabulia提出了建议,“不工作”并不是一个有用的回答。只有您可以看到您的屏幕,因此您需要让您的助手知道它是如何工作的。你能做什么观察?你看到错误了吗?如果你只是说“它不起作用”,那么别人就有责任问你更多的问题,这时他们就会猜测你需要做什么。
2020-01-22 20:22:48.353 28783-28783/? D/AndroidRuntime: Shutting down VM
2020-01-22 20:22:48.357 28783-28783/? E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.example.mysqlapp, PID: 28783
    java.lang.IllegalStateException: Could not execute method for android:onClick
        at androidx.appcompat.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:390)
        at android.view.View.performClick(View.java:6669)
        at android.view.View.performClickInternal(View.java:6638)
        at android.view.View.access$3100(View.java:789)
        at android.view.View$PerformClick.run(View.java:26145)
        at android.os.Handler.handleCallback(Handler.java:873)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:193)
        at android.app.ActivityThread.main(ActivityThread.java:6898)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:537)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
     Caused by: java.lang.reflect.InvocationTargetException
        at java.lang.reflect.Method.invoke(Native Method)
        at androidx.appcompat.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:385)
        at android.view.View.performClick(View.java:6669) 
        at android.view.View.performClickInternal(View.java:6638) 
        at android.view.View.access$3100(View.java:789) 
        at android.view.View$PerformClick.run(View.java:26145) 
        at android.os.Handler.handleCallback(Handler.java:873) 
        at android.os.Handler.dispatchMessage(Handler.java:99) 
        at android.os.Looper.loop(Looper.java:193) 
        at android.app.ActivityThread.main(ActivityThread.java:6898) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:537) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858) 
     Caused by: java.lang.NumberFormatException: For input string: ""
        at java.lang.Integer.parseInt(Integer.java:627)
        at java.lang.Integer.parseInt(Integer.java:650)
        at com.example.mysqlapp.MainActivity.OnClick(MainActivity.java:65)