如何根据电子邮件获取所有列值?

问题描述 投票:-2回答:1

我想从表tblReg中获取我的所有列。它具有列注册,名称,密码,电子邮件和联系人,在注册时检查电子邮件,它是唯一的列;值只存在于一个电子邮件的表中一次。

我通过将电子邮件与密码匹配并通过我的家庭活动中的意图传递电子邮件的价值作为KeyName进行登录。现在我想根据我的电子邮件从SQLlite获取所有细节,我通过Intent从getExtra收到。

这是我的家庭活动代码

public class activity_home extends Activity {
    DatabaseHandler dbh = new DatabaseHandler(this);
String regid,emailid,name,contact,data;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_activity_home);
        TextView lblEmail = (TextView) findViewById(R.id.textView1);
        TextView lblReg = (TextView) findViewById(R.id.textView1);
        TextView lblName = (TextView) findViewById(R.id.textView1);
        dbh.open();
        try {
            data = getIntent().getExtras().getString("keyName");

            Cursor m1 = dbh.getAllData(data);
            if (m1 != null) {
                m1.moveToFirst();
                name = m1.getString(m1.getColumnIndex("Name"));
                regid = m1.getString(m1.getColumnIndex("Registration"));
                contact = m1.getString(m1.getColumnIndex("Contact"));
                emailid = m1.getString(m1.getColumnIndex("Email"));
                m1.close();
            }

            if (!data.equals("")) {

                lblEmail.setText(Html.fromHtml("Email: <b>" + emailid + "</b>"));
                lblReg.setText(Html.fromHtml("Email: <b>" + regid + "</b>"));
                lblName.setText(Html.fromHtml("Email: <b>" + name + "</b>"));
            } else {
                Toast.makeText(getApplicationContext(), "Data Null Aya hai Bhai", Toast.LENGTH_SHORT).show();
            }
        }
        catch (Exception e)
        {
            String ex=e.toString();
            Toast.makeText(getApplicationContext(), ex, Toast.LENGTH_SHORT).show();
        }
            }

我使用了database handler类,我在使用查询,我认为查询中存在问题,请查看。我正在共享游标代码,我错在哪里?

 public Cursor getAllData(String parentKey) {

    String[] fields = new String[] {
            KEY_REGID,
            KEY_NAME,
            KEY_PASSWORD,
            KEY_EMAIL,
            KEY_MOBILENO + " as _id "
    };

    Cursor cursor = mDb.query(tblReg,
            fields,
            KEY_EMAIL + " = ?",
            new String[] {
                    "" + parentKey
            },
            null,
            null,
            KEY_NAME);

    cursor.moveToFirst();
    return cursor;
}
android sqlite android-intent homescreen
1个回答
0
投票

我已经解决了基于column值从表中获取数据的问题,现在我想分享一些草率的错误。

TextView lblEmail = (TextView) findViewById(R.id.textView1);
            TextView lblReg = (TextView) findViewById(R.id.textView1);
            TextView lblName = (TextView) findViewById(R.id.textView1);

此代码必须如下所述编写

TextView lblEmail = (TextView) findViewById(R.id.textView1);
                TextView lblReg = (TextView) findViewById(R.id.textView2);
                TextView lblName = (TextView) findViewById(R.id.textView3);

其余的都工作得很好,任何观众想要学习如何根据用户传递的值获取所有列值可以参考上面的代码。

© www.soinside.com 2019 - 2024. All rights reserved.