Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/224.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 从sqlite raw获取id并将其设置为整数类型_Java_Android_Sqlite - Fatal编程技术网

Java 从sqlite raw获取id并将其设置为整数类型

Java 从sqlite raw获取id并将其设置为整数类型,java,android,sqlite,Java,Android,Sqlite,您好,我在android中开发了注册屏幕,我需要通过输入的用户名和密码从我的数据库中获取id,该用户名和密码存储数据库并将其设置为int。首先,用户将注册,然后键入名称,然后进行传递和登录。在我的数据库中,我有许多RAW,如:id用户名密码。我想获取输入的用户名和密码的id。例如:id:1用户名:A pass:A id:2,用户名:B pass:B。。当用户A输入他的名字,通过并登录时,我应该得到他的id,然后将其设置为int类型,如果您不知道,请留下评论谢谢 我试图尝试,但我不知道它是否正确以

您好,我在android中开发了注册屏幕,我需要通过输入的用户名和密码从我的数据库中获取id,该用户名和密码存储数据库并将其设置为int。首先,用户将注册,然后键入名称,然后进行传递和登录。在我的数据库中,我有许多RAW,如:id用户名密码。我想获取输入的用户名和密码的id。例如:id:1用户名:A pass:A id:2,用户名:B pass:B。。当用户A输入他的名字,通过并登录时,我应该得到他的id,然后将其设置为int类型,如果您不知道,请留下评论谢谢 我试图尝试,但我不知道它是否正确以及如何开发:

EditText name;
 String Username = name.getText().toString();

Cursor c = database.rawQuery("SELECT * FROM " +LOGIN_TABLE  + " where username = '"+Username+"'", null);

在这个代码中,登录表是我的表名吗?

从数据库中获取id,如下所示:

String id = c.getString(1);//c is object of cursor
然后使用integer.parseInt将其转换为整数


如果您使用的是数据库的内置id字段,我建议稍微更改一下查询

我发现,如果我没有在CREATETABLE语句中定义_id行,我就不会在Select*语句中得到它

游标c=database.rawQuerySELECT*FROM+LOGIN_TABLE+,其中username='+username+',null

可以切换到:

游标c=database.rawQuerySELECT_id,*FROM+LOGIN_TABLE+,其中username='+username+',null

之后,当您从光标获取该id时,使用以下命令查找id:

Long id=c.getLongc.getColumnIndex\u id

编辑:

在这里调用最后一行代码之前,请确保将光标移动到第一个结果

if (c.moveToFirst())
{
    id = c.getLong(c.getColumnIndex("_id"));
}

粘贴您尝试的字符串id=c.getString1;这是get only id=1?谢谢,但当我输入用户名和密码时,它会显示长id=c.getLongc.getColumnIndex_id;无法工作-android.database.CursorIndexOutOfBoundsException:请求索引-1,大小为1,可以是什么?请检查c.getColumnIndex\u id返回的内容。如果这不是-1,那么结果游标就不会移动到游标中的第一个选项。检查编辑。非常感谢它的工作原理,但是你怎么知道它是moveToFirst方法而不是moveToNext?很抱歉问这个问题,但我是android开发的新手。我不太了解这个方法,请您回答MoveToFirst将光标指向光标中的第一项。如果您正在搜索具有多个结果的内容,您将在moveToFirst之后使用moveToNext来浏览所有结果。此代码不是回答问题的好方法,请提供更多详细信息
if (c.moveToFirst())
{
    id = c.getLong(c.getColumnIndex("_id"));
}
public void addData(View view){
    DBHandler dbHandler = new DBHandler(this);
    //normally the id is comming as int , i changed it to string
    long val = dbHandler.addInfo(username.getText().toString(), password.getText().toString());

    if(val > 0){
        Toast.makeText(this, "Inserted Successfully", Toast.LENGTH_LONG).show();
    }else{
        Toast.makeText(this, "Inserting Error", Toast.LENGTH_LONG).show();
    }
}