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

时间:2015-06-20 09:52:23

标签: android sqlite android-intent homescreen

我想从表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;
}

1 个答案:

答案 0 :(得分: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);

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