从sqlite数据库加载的微调器中检索所选元素的id

时间:2013-10-21 13:59:23

标签: android spinner android-spinner

我想要检索的Id应该与sqlite数据库中的ID相同,而不是微调器的项目行的id。

我使用了以下链接中的代码并获得了一些例外。

  

load from spinner sqlite with text and value

我认为问题在于:

anId = Integer.valueOf(( (AnSco) spnAnsco.getSelectedItem () ).getIdan());

我试着这样做:

anId = ( (AnSco) spnAnsco.getSelectedItem () ).getIdan();

始终存在同样的问题。

加载微调器

private void loadSpinnerAnsco() {
        List<String> ansco = new ArrayList<String>();
        db = new DatabaseHelper(this);
        boolean ok = true;
        try {
            SQLiteDatabase dbs = db.getWritableDatabase();

            cursor = dbs.rawQuery(
                    "Select idan as _id, ansco from TAnSco order by ansco",
                    null);

            // looping through all rows and adding to list
            if (cursor.moveToFirst()) {
                do {
                    ansco.add(cursor.getString(1));
                } while (cursor.moveToNext());
            }

            // closing connection
            cursor.close();
            dbs.close();

            ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>(this,
                    android.R.layout.simple_spinner_item, ansco);

            // Drop down layout style - list view with radio button
            dataAdapter
                    .setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

            // attaching data adapter to spinner
            spnAnsco.setAdapter(dataAdapter);

        } catch (Exception ex) {
            ok = false;
            AlertDialog.Builder b = new AlertDialog.Builder(this);
            b.setMessage(ex.toString());
            b.show();
        } finally {
            if (ok) {
                db.close();
            }
        }

    }

获取项目选择

public class anscoSpinner implements OnItemSelectedListener {

        @Override
        public void onItemSelected(AdapterView<?> parent, View view,
                int position, long id) {
            String label = parent.getItemAtPosition(position).toString();
            AnSco an=new AnSco(label);
            anId = Integer.valueOf(( (AnSco) spnAnsco.getSelectedItem () ).getIdan());
            loadSpinnerPeriode(anId);
            // Showing selected spinner item
            Toast.makeText(parent.getContext(), "You selected: " + label+ " AnId: "+anId,
                    Toast.LENGTH_LONG).show();
        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {
            // TODO Auto-generated method stub

        }
        // TODO Auto-generated method stub

    }

Object Class Ansco

public class AnSco {

    int idan;
    String ansco;

    public AnSco(int idan, String ansco) {
        this.idan = idan;
        this.ansco = ansco;
    }

    public AnSco(String ansco) {
        this.ansco = ansco;
    }

    public AnSco() {
        // TODO Auto-generated constructor stub
    }

    public int getIdan() {
        return idan;
    }
    public void setIdan(int idan) {
        this.idan = idan;
    }

    public String getAnsco() {
        return ansco;
    }
    public void setAnsco(String ansco) {
        this.ansco = ansco;
    }

}

StackTrace:

10-21 13:34:59.319: E/AndroidRuntime(438): FATAL EXCEPTION: main
10-21 13:34:59.319: E/AndroidRuntime(438): java.lang.ClassCastException: java.lang.String
10-21 13:34:59.319: E/AndroidRuntime(438):  at com.android.moyenne.activity.MoyenneMain$anscoSpinner.onItemSelected(MoyenneMain.java:306)
10-21 13:34:59.319: E/AndroidRuntime(438):  at android.widget.AdapterView.fireOnSelected(AdapterView.java:864)
10-21 13:34:59.319: E/AndroidRuntime(438):  at android.widget.AdapterView.access$200(AdapterView.java:42)
10-21 13:34:59.319: E/AndroidRuntime(438):  at android.widget.AdapterView$SelectionNotifier.run(AdapterView.java:830)
10-21 13:34:59.319: E/AndroidRuntime(438):  at android.os.Handler.handleCallback(Handler.java:587)
10-21 13:34:59.319: E/AndroidRuntime(438):  at android.os.Handler.dispatchMessage(Handler.java:92)
10-21 13:34:59.319: E/AndroidRuntime(438):  at android.os.Looper.loop(Looper.java:123)
10-21 13:34:59.319: E/AndroidRuntime(438):  at android.app.ActivityThread.main(ActivityThread.java:4627)
10-21 13:34:59.319: E/AndroidRuntime(438):  at java.lang.reflect.Method.invokeNative(Native Method)
10-21 13:34:59.319: E/AndroidRuntime(438):  at java.lang.reflect.Method.invoke(Method.java:521)
10-21 13:34:59.319: E/AndroidRuntime(438):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
10-21 13:34:59.319: E/AndroidRuntime(438):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
10-21 13:34:59.319: E/AndroidRuntime(438):  at dalvik.system.NativeStart.main(Native Method)
10-21 13:35:02.119: I/Process(438): Sending signal. PID: 438 SIG: 9

1 个答案:

答案 0 :(得分:1)

  

我使用了这个教程load from spinner sqlite with text and value并在运行期间获得了一些例外。

我在您提供的链接中使用了解决方案。我建议进行以下更改。

在您的DatabaseClass中创建以下方法

public List < Ansco> getAllLabels(){
    List < Ansco > lansco = new ArrayList < Ansco > ();
    // Select All Query
    String selectQuery = "SELECT  * FROM "  TAnSco;// tAnsco is your table name?

    SQLiteDatabase db = this.getReadableDatabase();
    Cursor cursor = db.rawQuery(selectQuery, null);

    // looping through all rows and adding to list
    if ( cursor.moveToFirst () ) {
        do {
            lansco.add ( new Ansco ( cursor.getString(0) , cursor.getString(1) ) );
        } while (cursor.moveToNext());
    }

    // closing connection
    cursor.close();
    db.close();

    // returning labels
    return lansco;
}

然后在你的加载微调器方法

 List <Ansco> ansco = db.getAllLabels();
 ArrayAdapter<Ansco> dataAdapter = new ArrayAdapter<Ansco>(this,
                android.R.layout.simple_spinner_item, ansco);
 dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
 spnAnsco.setAdapter(dataAdapter);

然后在您的微调器选择中

  int databaseId = Integer.parseInt ( ( (SpinnerObject) spin2.getSelectedItem () ).getId () );

并更改你的Ansco课程

public class AnSco {

    String idan; // change to string
    String ansco;

    public AnSco(String idan, String ansco) {
        this.idan = idan;
        this.ansco = ansco;
    }

    public AnSco(String ansco) {
        this.ansco = ansco;
    }

    public AnSco() {
        // TODO Auto-generated constructor stub
    }

    public String getIdan() {
        return idan;
    }
    public void setIdan(String idan) {
        this.idan = idan;
    }

    public String getAnsco() {
        return ansco;
    }
    public void setAnsco(String ansco) {
        this.ansco = ansco;
    }

}