一、注册功能中添加数据不成功
给数据库添加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键才能返回
因为之前添加数据不成功导致数据库里存在空字符串数据,没有输入用户名和密码的时候,其实已经在和数据库中的空字符串数据进行了比较,所以导致登录成功,并且由于查询代码处于一个循环,所以有多少空字符串就循环了多少次,也就出现了重复的活动