将输入数据与另一个表进行比较

时间:2019-02-01 11:24:08

标签: java android firebase firebase-realtime-database

我正在开发的应用程序中有一个“注册”选项,为了验证谁可以注册,我创建了另一个名为ORDER的表格。

此表Order具有两个字段(名称和编号)。

“注册”已连接到表USERS,我想将“注册”上插入的名称和号码与表ORDER中插入的数据进行比较。

例如:

注册 用户名:test 密码:测试 名称:用户测试 编号:12345

订购: 名称:用户测试 编号:12345

只有名称和号码在ORDER表中,它才能在USER表中注册注册信息。

你能帮我吗?

FirebaseDatabase database;
DatabaseReference Users, Order;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);


    database = FirebaseDatabase.getInstance();
    Users = database.getReference("Users");
    Order = database.getReference("Order");

    edtUser =(MaterialEditText) findViewById(R.id.edtUserName);
    edtPassword =(MaterialEditText)findViewById(R.id.edtPassword);

    btnSignIn= (Button)findViewById(R.id.btn_sign_in);
    btnSignUp= (Button)findViewById(R.id.btn_sign_up);

    btnSignUp.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            showSignUpDiaolog();

        }
    });
    btnSignIn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            signIn(edtUser.getText().toString(),edtPassword.getText().toString());
        }
    });
}


private void signIn(final String user, final String pwd) {
    Users.addListenerForSingleValueEvent(new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {
            if(dataSnapshot.child(user).exists())
            {
                if(!user.isEmpty())
                {
                    User login = dataSnapshot.child(user).getValue(User.class);
                    if (login.getPassword().equals(pwd))
                    {
                        Intent homeActivity = new Intent(MainActivity.this,Home.class);
                        Common.currentUser = login;
                        startActivity(homeActivity);
                        finish();
                    }
                    else
                    {
                        Toast.makeText(MainActivity.this, "Password errada!", Toast.LENGTH_SHORT).show();
                    }}
                else
                {
                    Toast.makeText(MainActivity.this, "Introduza o utilizador!", Toast.LENGTH_SHORT).show();
                }
            }
            else
            {
                Toast.makeText(MainActivity.this, "Utilizador não existe!", Toast.LENGTH_SHORT).show();
            }
        }
        @Override
        public void onCancelled(DatabaseError databaseError) {

        }
    });
}

private void showSignUpDiaolog() {
    AlertDialog.Builder alertDialog = new AlertDialog.Builder(MainActivity.this);
    alertDialog.setTitle("Criação da conta:");
    alertDialog.setMessage("Preencher todos os campos!");

    LayoutInflater inflater = this.getLayoutInflater();
    View sign_up_layout = inflater.inflate(R.layout.sign_up_layout,null);

    edtNewUser = (MaterialEditText)sign_up_layout.findViewById(R.id.edtNewUserName);
    edtNewPassword = (MaterialEditText)sign_up_layout.findViewById(R.id.edtNewPassword);
    edtNewOrdem = (MaterialEditText)sign_up_layout.findViewById(R.id.edtNewOrdem);
    edtNewName = (MaterialEditText)sign_up_layout.findViewById(R.id.edtNewName);


    alertDialog.setView(sign_up_layout);
    alertDialog.setIcon(R.drawable.ic_account_circle_black_24dp);
    alertDialog.setNegativeButton("Cancelar", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            dialogInterface.dismiss();

        }
    });
    alertDialog.setPositiveButton("Confirmar", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialogInterface, int i) {
            final User user = new User (
                    edtNewUser.getText().toString(),
                    edtNewPassword.getText().toString(),
                    edtNewOrdem.getText().toString(),
                    edtNewName.getText().toString());


                Users.addListenerForSingleValueEvent(new ValueEventListener() {
                @Override
                public void onDataChange(DataSnapshot dataSnapshot)
                {
                    String passwordvalid = edtNewPassword.getText().toString();
                    String usernamevalid = edtNewUser.getText().toString();


                    if (TextUtils.isEmpty(passwordvalid))
                    {
                        Toast.makeText(MainActivity.this, "Password não definida.", Toast.LENGTH_SHORT).show();
                        return;
                    }
                    if (TextUtils.isEmpty(usernamevalid))
                    {
                        Toast.makeText(MainActivity.this, "Utilizador não definido.", Toast.LENGTH_SHORT).show();
                        return;
                    }
                    if (passwordvalid.length() < 8)
                    {
                        Toast.makeText(MainActivity.this, "Password tem que conter no mínimo 8 caracteres.", Toast.LENGTH_SHORT).show();
                        return;
                    }
                    if(dataSnapshot.child(user.getUserName()).exists())
                        Toast.makeText(MainActivity.this, "Utilizador já registado!", Toast.LENGTH_SHORT).show();
                    else
                    {
                        Users.child(user.getUserName())
                                .setValue(user);
                        Toast.makeText(MainActivity.this, "Registo efetuado!", Toast.LENGTH_SHORT).show();
                    }

                }

                @Override
                public void onCancelled(DatabaseError databaseError) {

                }
            });
            dialogInterface.dismiss();

        }
    });
    alertDialog.show();
}

}

2 个答案:

答案 0 :(得分:0)

为此,您应该将 username 列设置为 unique_key ,而不要创建另一个表。

例如,如果要创建表,则在 PostgreSQL 中:

CREATE TABLE users (
    id SERIAL,
    username varchar UNIQUE,
    password varchar,
    name varchar,
    test_number integer
);

UNIQUE约束将拒绝使用现有用户名创建的任何行。 对于其他 RDBMS ,语法会稍有不同,但几乎相同。

在表格上添加ID

由于效率和结构问题,每个表都应始终有一个id。一个ID将会使行唯一独立于其他特性,它也将提供更快的方法,使连接查询。一个ID,它与数据无关,您不必担心通过可能已更改或未更改的字段查找行。

答案 1 :(得分:0)

Tables

如您所见,我想检查用户名和名称是否已在订单表中注册。如果不是,则无法在用户表上注册。如果是,则将信息记录在“用户表”上并创建帐户。

我有一个可以在应用程序上注册的人员列表,我想用这两个字段进行控制。