请求android cursorindexoutofbounds索引0

时间:2014-08-22 00:42:37

标签: java android sqlite android-cursor

我试图从fRate等于(货币符号,USD,JPY等)的表中返回一行(每个表一个),然后将该行的列转换为浮点数。每当spinner2被设置为默认选择(即AUD,我的数据库中的第一个表)之外的某些东西,我得到错误。

    Button convert = (Button) rootView.findViewById(R.id.button1);
    convert.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            context = getActivity().getApplicationContext();
            DataBaseHelper dbHelper = new DataBaseHelper(context);
            try {
                dbHelper.createDataBase();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            dbHelper.openDataBase();
            db = dbHelper.getWritableDatabase();

            String lRate = spinner1.getSelectedItem().toString();
            String fRate = spinner2.getSelectedItem().toString();       
            Cursor c = db.rawQuery("SELECT * FROM "+fRate+" ", null);
            c.moveToNext();
            Float cfRate = c.getFloat(c.getColumnIndexOrThrow(lRate));
                c.close(); 



            answer.setText(String.valueOf((Float.parseFloat(amount.getText().toString()) * cfRate)));
            inputManager.hideSoftInputFromWindow(getView().getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS);
            db.close();
        }
    });

我一直在这一行得到错误:

Float cfRate = c.getFloat(c.getColumnIndexOrThrow(lRate));

1 个答案:

答案 0 :(得分:0)

AUD以外的表格为空,因此您会收到错误消息,告知您找不到任何项目。如果您希望它们起作用,您需要使用数据填充这些表。