我试图从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));
答案 0 :(得分:0)
AUD
以外的表格为空,因此您会收到错误消息,告知您找不到任何项目。如果您希望它们起作用,您需要使用数据填充这些表。