一、注册功能中添加数据不成功
给数据库添加EditText中的内容后,数据库中找不到添加后的数据,并且存在字符串为空的数据
解决方法:EditText registerAccount = (EditText)findViewById(R.id.register_account);和EditText registerPassword = (EditText)findViewById(R.id.register_password);必须写在onClick()方法中,不然获取不到EditText的值
public class RegisterActivity extends AppCompatActivity { private MyDatabaseHelper dbHelper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.register); dbHelper = new MyDatabaseHelper(this, "UserStore.db", null, 1); Button okButton = (Button)findViewById(R.id.ok); okButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); EditText registerAccount = (EditText)findViewById(R.id.register_account); EditText registerPassword = (EditText)findViewById(R.id.register_password); String username = registerAccount.getText().toString(); String password = registerPassword.getText().toString(); if (!((username.equals("")) || (password.equals("")))) { values.put("name", username); values.put("password", password); db.insert("User", null, values); Toast.makeText(RegisterActivity.this, "注册成功", Toast.LENGTH_SHORT).show(); Intent intent = new Intent(RegisterActivity.this, LoginActivity.class); startActivity(intent); } else { Toast.makeText(RegisterActivity.this, "用户名或密码不能为空", Toast.LENGTH_SHORT).show(); } } }); } }
二、字符串比较
字符串之间值的比较要用.equals(),不能用“==”
三、没有输入用户名和密码却能登陆成功,并且需要按多次Back键才能返回
因为之前添加数据不成功导致数据库里存在空字符串数据,没有输入用户名和密码的时候,其实已经在和数据库中的空字符串数据进行了比较,所以导致登录成功,并且由于查询代码处于一个循环,所以有多少空字符串就循环了多少次,也就出现了重复的活动