第二个微调器没有根据sqlite中的前一个微调器加载

时间:2016-10-05 08:38:30

标签: android sqlite spinner

我从sqlite填充了两个微调器。现在,当我的Activity创建时,我想要的是所有状态填充在spnState中。但是当我从微调器中选择任何状态时,我想从spnDistrict中的sqlite绑定区域。当我在区域旋转器中没有显示的区域列表之后选择状态时,我遇到问题它只显示"选择区域#34;。我怎样才能做到这一点。

public void SpinnerValue(){
    /*-----------------------Fill State start here----------------------------*/

            try {
                ArrayList<String> state_array = new ArrayList<String>();
                state_array.add("Select State");
                Cursor cursor_State = db.rawQuery("SELECT nSerialNo as _id,cCodeName FROM CodeMaster where nCtgId = 6", null);


                if (cursor_State.moveToFirst()) {
                    do {
                        //assing values
                        String stateID = cursor_State.getString(0);
                        String stateName = cursor_State.getString(1);
                        stateData = stateName;
                        state_array.add(stateData);


                    } while (cursor_State.moveToNext());
                }
                ArrayAdapter my_Adapter = new ArrayAdapter(getActivity(), android.R.layout.simple_list_item_1, state_array);
                spnState.setAdapter(my_Adapter);
                cursor_State.close();
                spnState.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
                    @Override
                    public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {

                        state = spnState.getSelectedItem().toString();

                        Cursor cursor = db.rawQuery("SELECT nSerialNo FROM CodeMaster where cCodeName = '" + state + "'", null);

                        if (cursor.moveToFirst()) {
                            do {
                                //assing values
                                stateCodeId = cursor.getString(0);

                            } while (cursor.moveToNext());
                        }
                        cursor.close();
                    }

                    @Override
                    public void onNothingSelected(AdapterView<?> parent) {

                    }


                });
            } catch (Exception e) {

                e.printStackTrace();

            }

            /*-----------------------Fill District start here----------------------------*/

            try {
                ArrayList<String> district_array = new ArrayList<String>();
                district_array.add("Select District");
                Cursor cursor_District = db.rawQuery("SELECT nSerialNo as _id,cCodeName FROM CodeMaster where nParentSerialNo = '"+stateCodeId+"'", null);


                if (cursor_District.moveToFirst()) {
                    do {
                        //assing values
                        String districtID = cursor_District.getString(0);
                        String districtName = cursor_District.getString(1);
                        districtData = districtName;
                        district_array.add(districtData);


                    } while (cursor_District.moveToNext());
                }
                ArrayAdapter district_Adapter = new ArrayAdapter(getActivity(), android.R.layout.simple_list_item_1, district_array);
                spnDistrict.setAdapter(district_Adapter);
                cursor_District.close();
                spnDistrict.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
                    @Override
                    public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {

                        district = spnDistrict.getSelectedItem().toString();

                        Cursor cursor = db.rawQuery("SELECT nSerialNo FROM CodeMaster where cCodeName = '" + district + "'", null);

                        if (cursor.moveToFirst()) {
                            do {
                                //assing values
                                districtCodeId = cursor.getString(0);

                            } while (cursor.moveToNext());
                        }
                        cursor.close();

                    }

                    @Override
                    public void onNothingSelected(AdapterView<?> parent) {

                    }


                });
            } catch (Exception e) {

                e.printStackTrace();

            }
}

1 个答案:

答案 0 :(得分:1)

我已经检查了你的代码,你用一个简单的方法设置所有的值,因此不需要stateId来获取区域,所以只需应用下面的两个方法并在onCreate方法中首先调用来解决你的问题,

在onCreate()方法中调用以下方法

  // In onCreate() method call below method
  fillStateData();

  public void fillStateData()
  {
     try {
           ArrayList<String> state_array = new ArrayList<String>();
           state_array.add("Select State");
           Cursor cursor_State = db.rawQuery("SELECT nSerialNo as _id,cCodeName FROM CodeMaster where nCtgId = 6", null);


           if (cursor_State.moveToFirst()) 
           {
               do {
                    //assing values
                    String stateID = cursor_State.getString(0);
                    String stateName = cursor_State.getString(1);
                    stateData = stateName;
                    state_array.add(stateData);
                } while (cursor_State.moveToNext());
            }
            ArrayAdapter my_Adapter = new ArrayAdapter(getActivity(), android.R.layout.simple_list_item_1, state_array);
            spnState.setAdapter(my_Adapter);
            cursor_State.close();
            spnState.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
                @Override
                public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {

                    state = spnState.getSelectedItem().toString();

                    Cursor cursor = db.rawQuery("SELECT nSerialNo FROM CodeMaster where cCodeName = '" + state + "'", null);

                    if (cursor.moveToFirst()) {                        
                            stateCodeId = cursor.getString(0);
                    }
                    cursor.close();

                   fillDistrictData(stateCodeId);
                }

                @Override
                public void onNothingSelected(AdapterView<?> parent) {

                }
            });
        } catch (Exception e) {

            e.printStackTrace();

        }
   }






public void fillDistrictData(String stateCodeId)
{
        try {
                ArrayList<String> district_array = new ArrayList<String>();
                district_array.add("Select District");
                Cursor cursor_District = db.rawQuery("SELECT nSerialNo as _id,cCodeName FROM CodeMaster where nParentSerialNo = '"+stateCodeId+"'", null);


                if (cursor_District.moveToFirst()) {
                    do {
                        //assing values
                        String districtID = cursor_District.getString(0);
                        String districtName = cursor_District.getString(1);
                        districtData = districtName;
                        district_array.add(districtData);


                    } while (cursor_District.moveToNext());
                }
                ArrayAdapter district_Adapter = new ArrayAdapter(getActivity(), android.R.layout.simple_list_item_1, district_array);
                spnDistrict.setAdapter(district_Adapter);
                cursor_District.close();
                spnDistrict.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
                    @Override
                    public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {

                        district = spnDistrict.getSelectedItem().toString();

                        Cursor cursor = db.rawQuery("SELECT nSerialNo FROM CodeMaster where cCodeName = '" + district + "'", null);

                        if (cursor.moveToFirst()) {
                            do {
                                //assing values
                                districtCodeId = cursor.getString(0);

                            } while (cursor.moveToNext());
                        }
                        cursor.close();

                    }

                    @Override
                    public void onNothingSelected(AdapterView<?> parent) {

                    }


                });
            } catch (Exception e) {

                e.printStackTrace();

            }

   }