Java 存储用户在手机上创建的数据。请看这篇文章

Java 存储用户在手机上创建的数据。请看这篇文章,java,android,Java,Android,我的情况是下一个。我正在创建一个应用程序,当你可以做一个调查,然后,你可以看到调查答案,点击按钮,在应用程序中,而不去电话文件或类似的东西。我已经创建了大约55%的应用程序,但其他45%是最重要的。有多少可能性,或者我可以做些什么来实现这一点,当一个人点击应用程序内的按钮时,可以看到调查答案。我做了界面、按钮、文本视图等。。我创建了一个数据库,认为创建它,就有可能实现我想要的。我希望当你可以做一个调查,然后按下一个按钮,打开一个新的活动,并看到调查的答案时,你可以做一个系统。当您关闭应用程序并再

我的情况是下一个。我正在创建一个应用程序,当你可以做一个调查,然后,你可以看到调查答案,点击按钮,在应用程序中,而不去电话文件或类似的东西。我已经创建了大约55%的应用程序,但其他45%是最重要的。有多少可能性,或者我可以做些什么来实现这一点,当一个人点击应用程序内的按钮时,可以看到调查答案。我做了界面、按钮、文本视图等。。我创建了一个数据库,认为创建它,就有可能实现我想要的。我希望当你可以做一个调查,然后按下一个按钮,打开一个新的活动,并看到调查的答案时,你可以做一个系统。当您关闭应用程序并再次打开时,调查答案不会消失,它们仍然保存。谢谢

以下是我的调查代码,XML和JAVA:

Button sig = (Button) findViewById(R.id.env); // cargo el boton
    encuestadoSQLiteHelper encuestado = new encuestadoSQLiteHelper(this, "DBEncuestado", null, 1); // base de datos
    final SQLiteDatabase db = encuestado.getWritableDatabase();


    sig.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Context context = getApplicationContext();
            EditText preg5 = (EditText) findViewById(R.id.editText2);
            EditText preg4 = (EditText) findViewById(R.id.editText);
            Spinner cur = (Spinner) findViewById(R.id.spinnerp);
            EditText nom = (EditText) findViewById(R.id.editText3);
            RadioGroup gruporadio = (RadioGroup) findViewById(R.id.Grupo1);
            RadioGroup gruporadio2 = (RadioGroup) findViewById(R.id.Grupo2);
            RadioGroup gruporadio3 = (RadioGroup) findViewById(R.id.Grupo3);
            String strNombre = nom.getText().toString();
            String nombre = "PabloGonzalez";
            String curso =  cur.getSelectedItem().toString();
            String strPregCinco = preg5.getText().toString();
            String strPregCuatro = preg4.getText().toString();

            if(gruporadio.getCheckedRadioButtonId() == -1 || gruporadio2.getCheckedRadioButtonId() == -1  || gruporadio3.getCheckedRadioButtonId() == -1 )
            {
                Toast.makeText(context,"¡No marcaste ninguna respuesta!",Toast.LENGTH_LONG).show();
            }

            else if (strNombre.matches("") || strPregCinco.matches("") || strPregCuatro.matches(""))
            {
                Toast.makeText(context,"¡Dejaste campos vacíos!",Toast.LENGTH_LONG).show();
            }

            else if(db == null)
            {
                Toast.makeText(context, "No funciona la base de datos.", Toast.LENGTH_LONG).show();
                db.close();
            }

            else
            {
                Intent i = new Intent (encuesta.this, res8.class);
                i.putExtra("nombre", strNombre);
                startActivity(i);
                Intent pas = new Intent(encuesta.this, MainActivity.class);
                Toast.makeText(context,"¡Encuesta enviada!",Toast.LENGTH_LONG).show();
                startActivity(pas);
                db.execSQL("INSERT INTO Encuestado (nombre) " +
                        "VALUES ('" + nombre +"')");
                db.close();
                new Thread(new Runnable() {
                    @Override
                    public void run() {
                        try {
                            File sd = Environment.getExternalStorageDirectory();
                            File data = Environment.getDataDirectory();

                            if (sd.canWrite()) {
                                String currentDBPath = "/data/com.example.pablo.myapplication/databases/DBEncuestad‌​o";
                                String backupDBPath = "backdatabase.sqlite";
                                File currentDB = new File(data, currentDBPath);
                                File backupDB = new File(sd, backupDBPath);

                                if (currentDB.exists()) {
                                    FileChannel src = new FileInputStream(currentDB).getChannel();
                                    FileChannel dst = new FileOutputStream(backupDB).getChannel();
                                    dst.transferFrom(src, 0, src.size());
                                    src.close();
                                    dst.close();
                                }
                            }
                        } catch (Exception e) {
                            System.out.println("error in data base copy:"+e);
                        }
                    }
                }).start();
            }
        }
    });

}
}

如果你能看到,有一个数据库,但我不知道这是不是必要的或是

XML:



我想展示答案的活动是res8.java

Bro,只需创建一个像getter和setter这样的模型类,首先创建像getQuestion()、setQuestion()、getAnswer()和setAnswer()这样的方法。然后,当用户回答您的调查问题时,只需创建该模型类的对象,如:-

ArrayList<MyModel> datalist = new ArrayList();
    MyModel model = new MyModel();
    model.setQuestion(list.get(i).question);
    model.setAnswer(list.get(i).answer);
    ....
    ....
  dataList.add(model);
ArrayList datalist=new ArrayList();
MyModel model=新的MyModel();
model.setQuestion(list.get(i).question);
model.setAnswer(list.get(i.answer));
....
....
添加(模型);
这样只需捕获所有用户输入的数据,不需要在这个数据库中

这里的列表是你所有问题的列表


当你想获取数据时,只需调用datalist.get(i).getQuestion,类似地,还有答案。

你做了什么,你想做什么,你希望如何做你想做的事?我做了界面、按钮、文本视图等。。我创建了一个数据库,认为创建它,就有可能实现我想要的。我希望当你可以做一个调查,然后按下一个按钮,打开一个新的活动,并看到调查的答案时,你可以做一个系统。当你关闭应用程序并再次打开时,调查答案不会消失,它们仍然保存着。我建议你用持久化实现的详细信息更新你的问题,这样你就可以让数据库按详细信息(我是指代码)工作。定义一个表,插入和检索数据等等,我如何用我在问题上发布的代码来做到这一点?
ArrayList<MyModel> datalist = new ArrayList();
    MyModel model = new MyModel();
    model.setQuestion(list.get(i).question);
    model.setAnswer(list.get(i).answer);
    ....
    ....
  dataList.add(model);