根据单选按钮值将值存储在sqlite数据库的多个表中

时间:2016-08-29 08:30:06

标签: java android android-sqlite

在数据库中创建了名为adopter和donor的两个表。当'作为捐赠者'单击单选按钮,注册表的值应存储在正确工作的捐赠者表中。问题在于“作为采用者”的时间。单击单选按钮,值将存储在捐赠者表中,并且在采用者表中单独输入id(主键)。在这里'是'单选按钮是作为捐赠者'并且没有'单选按钮是'作为采用者'我需要你的帮助。

    findViewById(R.id.button2).setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            final String email = mail.getText().toString();
            final String name1 = name.getText().toString();
            final String pass = password.getText().toString();
            final String pass1 = password1.getText().toString();
            int id;
            id = student.getCheckedRadioButtonId();
            boolean check;
            check = stud.isChecked();
            if (!isValidName(name1)) {
                name.setError("Invalid name");
            }
            if (isValidName(name1) && !isValidEmail(email)) {
                mail.setError("Invalid Email");
            }
            if (isValidName(name1) && isValidEmail(email) && !isValidPassword(pass)) {
                password.setError("Invalid password");
            }
            if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass)) {

                if (!isValidPassword(pass1)) {
                    password1.setError("Invalid password");
                }
            }
            if (isValidPassword(pass) != isValidPassword(pass1)) {
                password1.setError("The given passwords does not match ");
            }

            if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (id == -1)) {
                Toast toast;
                toast = makeText(Register.this, "Click any one of the option", Toast.LENGTH_SHORT);
                toast.show();
            }
            if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && (id != -1) && isValidPassword(pass) == isValidPassword(pass1) && (check == false)) {
                Toast msg1;
                msg1 = makeText(Register.this, "You can not register without clicking this checkbox", Toast.LENGTH_SHORT);
                msg1.show();
            }
            if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass)  && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (yes.isEnabled()==true)) {
                Toast msg2;
                msg2 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
                msg2.show();
                    Intent launch;
                    launch = new Intent(Register.this, donor.class);
                    startActivity(launch);
                    donor_insert(view);

                if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (no.isEnabled()==true)){
                    Toast msg3;
                    msg3 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
                    msg3.show();
                    Intent adopter;
                    adopter = new Intent(Register.this, adopter.class);
                    startActivity(adopter);
                    adopter_insert(view);
                }

            }

        }
    });
}
private boolean isValidEmail(String email) {
    String EMAIL_PATTERN = "^(?=.*[a-z]).(?=\\S+$).{4,}$";

    Pattern pattern = Pattern.compile(EMAIL_PATTERN);
    Matcher matcher = pattern.matcher(email);
    return matcher.matches();
}
private boolean isValidName(String name) {
    String name1 = "^(?=.*[a-z]).{1,}$";
    Pattern pattern1 = Pattern.compile(name1);
    Matcher matcher1 = pattern1.matcher(name);
    return matcher1.matches();
}

// validating password with retype password
private boolean isValidPassword(String pass) {
    if (pass != null && pass.length() > 6) {
        return true;
    }
    return false;
}
public void adopter_insert(View view) {
     UserInputs adopt = new UserInputs(name.getText().toString(), mail.getText().toString(), password.getText().toString());
    dbHandler.adopter_insert(adopt);
    name.setText("");
    mail.setText("");
    password.setText("");
}
public void donor_insert(View view) {
    UserInputs donate = new UserInputs(name.getText().toString(), mail.getText().toString(), password.getText().toString());
    dbHandler.donor_insert(donate);
    name.setText("");
    mail.setText("");
    password.setText("");
}

}

{ //Dbhandler.java

public DBhandler(Context context, String name,
                 SQLiteDatabase.CursorFactory factory, int version) {
    super(context, DBNAME, null, 1);
}

@Override
public void onCreate(SQLiteDatabase db) {
    String create_table = ("CREATE TABLE " + TABLE + "("
            + COLUMN_ID1 + " INTEGER PRIMARY KEY," + COLUMN_NAME
            + " TEXT," + COLUMN_MAIL + " TEXT, " + COLUMN_PASSWORD + " BLOB " + ")");
    db.execSQL(create_table);
    String create_table1 = ("CREATE TABLE " + TABLE1 + "("
            + COLUMN_ID + " INTEGER PRIMARY KEY," + COLUMN_NAME
            + " TEXT," + COLUMN_MAIL + " TEXT, " + COLUMN_PASSWORD + " BLOB " + ")");
    db.execSQL(create_table1);
}

@Override
public void onUpgrade(SQLiteDatabase db, int i, int i1) {
    db.execSQL("DROP TABLE IF EXISTS " + TABLE);
    onCreate(db);
    db.execSQL("DROP TABLE IF EXISTS " + TABLE1);
    onCreate(db);
}

public void adopter_insert(UserInputs inputs) {
    ContentValues values = new ContentValues();
    values.put(COLUMN_NAME, inputs.getName());
    values.put(COLUMN_MAIL, inputs.getMail());
    values.put(COLUMN_PASSWORD, inputs.getPass());
    SQLiteDatabase db = this.getWritableDatabase();
    db.insert(TABLE, null, values);
    db.close();
}
public void donor_insert(UserInputs inputs) {
    ContentValues values1 = new ContentValues();
    values1.put(COLUMN_NAME, inputs.getName());
    values1.put(COLUMN_MAIL, inputs.getMail());
    values1.put(COLUMN_PASSWORD, inputs.getPass());
    SQLiteDatabase db = this.getWritableDatabase();
    db.insert(TABLE1, null, values1);
    db.close();
}

}

}

1 个答案:

答案 0 :(得分:0)

如果你需要设置这样的条件,你会在最后看到你,因为当你的捐赠者被检查时,你的第一个将被执行,如果你的采用者被检查,那么你的第二个将被执行。我希望这对你有所帮助。

if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass)  && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (yes.isEnabled()==true)) 
{
     Toast msg2;
     msg2 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
     msg2.show();
     Intent launch;
     launch = new Intent(Register.this, donor.class);
     startActivity(launch);
     donor_insert(view);
}
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (no.isEnabled()==true))
{
     Toast msg3;
     msg3 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
     msg3.show();
     Intent adopter;
     adopter = new Intent(Register.this, adopter.class);
     startActivity(adopter);
     adopter_insert(view);
}