Запрос суммы в sqlite в android

Я новичок в java, android и sqlite, и я застрял в этом. У меня есть столбцы: _id, type, amount (int), category, description.What, я пытаюсь получить сумму суммы определенной категории и сохранить их в int. Я знаю, что мне нужно предоставить ошибки, но это просто дает мне силу закрыть. Пожалуйста, помогите

public class TransactionReport extends Activity { private static SQLiteDatabase db; Cursor c; int amount; DbCrud localDbCrud = new DbCrud(this); @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.report); localDbCrud.open(); //localDatabase = localDbHelper.getWritableDatabase(); return this; c.moveToFirst(); do{ c = db.rawQuery("select sum(amount) from transaction_table where category = Salary ;", null); }while(c.moveToNext()); amount = c.getInt(0); c.close(); TextView ltxt = (TextView) findViewById(R.id.amt); ltxt.setText(""+amount); localDbCrud.close(); //localDatabase.close(); } } 

Было бы полезно, если бы объяснялось подробно, так как я полный noob, и я попытался найти решение, но не нашел его. Спасибо заранее

 10-10 03:55:29.828: E/AndroidRuntime(10229): FATAL EXCEPTION: main 10-10 03:55:29.828: E/AndroidRuntime(10229): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.hishighness.budgetracker/com.hishighness.budgetracker.TransactionReport}: java.lang.NullPointerException 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.os.Handler.dispatchMessage(Handler.java:99) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.os.Looper.loop(Looper.java:130) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.app.ActivityThread.main(ActivityThread.java:3687) 10-10 03:55:29.828: E/AndroidRuntime(10229): at java.lang.reflect.Method.invokeNative(Native Method) 10-10 03:55:29.828: E/AndroidRuntime(10229): at java.lang.reflect.Method.invoke(Method.java:507) 10-10 03:55:29.828: E/AndroidRuntime(10229): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:842) 10-10 03:55:29.828: E/AndroidRuntime(10229): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600) 10-10 03:55:29.828: E/AndroidRuntime(10229): at dalvik.system.NativeStart.main(Native Method) 10-10 03:55:29.828: E/AndroidRuntime(10229): Caused by: java.lang.NullPointerException 10-10 03:55:29.828: E/AndroidRuntime(10229): at com.hishighness.budgetracker.TransactionReport.onCreate(TransactionReport.java:27) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 10-10 03:55:29.828: E/AndroidRuntime(10229): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615) 10-10 03:55:29.828: E/AndroidRuntime(10229): ... 11 more 

Вот журнал.

прибавление
Я считаю, что вы хотите использовать localDBCrud.rawQuery() , а не db.rawQuery() .

оригинал
Я предполагаю, что у вас есть исключение NullPointerException. Вот:

 c.moveToFirst(); 

Вы пытаетесь использовать c прежде чем инициализировать его с помощью db.rawQuery() .


У вас есть еще несколько логических ошибок:

 c.moveToFirst(); do{ c = db.rawQuery("select sum(amount) from transaction_table where category = Salary ;", null); }while(c.moveToNext()); amount = c.getInt(0); c.close(); в c.moveToFirst(); do{ c = db.rawQuery("select sum(amount) from transaction_table where category = Salary ;", null); }while(c.moveToNext()); amount = c.getInt(0); c.close(); 

Попробуйте это вместо этого:

 c = db.rawQuery("select sum(amount) from transaction_table where category = Salary ;", null); if(c.moveToFirst()) amount = c.getInt(0); else amount = -1; c.close(); 

Также @toadsky сделал большое замечание, следуйте его совету тоже.

Вы должны обернуть строковые значения в одинарные кавычки. Поэтому вместо:

 select sum(amount) from transaction_table where category = Salary ; 

делать:

 select sum(amount) from transaction_table where category = 'Salary';