Spinner 从数据库中读取数据并实现2级互动

转载 2012年03月21日 15:39:42
这里主要实现了。省份和城市的二级关联。选择省份。二级对应的就是省份所有的城市

下面看代码;
        1.activity
        @Override
        protected void onCreate(Bundle savedInstanceState) {
                // TODO Auto-generated method stub
                super.onCreate(savedInstanceState);
                setContentView(R.layout.test_layout);
                this.mContext = this;
                Map<Integer,List> data = ProvinceDB.getProvince();//得到数据库数据
                provinceList = data.get(1);
                provinceData = data.get(0);
               
                ArrayAdapter provinceAdapter = new ArrayAdapter(mContext,android.R.layout.simple_spinner_item,provinceList);
                provinceAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); // 样式
               
                spProvince.setAdapter(provinceAdapter);
                spProvince.setOnItemSelectedListener(itemSelectedListener);
               
        }
       
        // 选择省份 联动 对应城市
        private OnItemSelectedListener itemSelectedListener = new OnItemSelectedListener() {
                @Override
                public void onItemSelected(AdapterView<?> parent, View view,
                                int position, long id) {
                        Spinner spProvince = (Spinner) parent;
                        String selProvince = (String) spProvince.getItemAtPosition(position);
                        ArrayAdapter cityAdapter = null;
                        Map<String,Integer> data = (Map)provinceData.get(position);//根据所选择的得到对应的省份id 然后得到城市
                        int pid = data.get(selProvince);//得到省份的id
                        List cityList = ProvinceDB.getCityByPid(pid);
                        cityAdapter  = new ArrayAdapter(mContext,android.R.layout.simple_spinner_item,cityList);
                        cityAdapter
                                        .setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
                        spCity.setAdapter(cityAdapter);
                        spCity.setOnItemSelectedListener(citySelectedListener);

                }

                @Override
                public void onNothingSelected(AdapterView<?> parent) {
                        // TODO Auto-generated method stub
                }
        };
       
        String selectedCity = null;
        private OnItemSelectedListener citySelectedListener = new OnItemSelectedListener() {
                @Override
                public void onItemSelected(AdapterView<?> parent, View view,
                                int position, long id) {
                        Spinner spCity = (Spinner) parent;
                        selectedCity = (String) spCity.getItemAtPosition(position);
                }

                @Override
                public void onNothingSelected(AdapterView<?> parent) {
                        // TODO Auto-generated method stub
                }
        };
       
        2.DB类查询数据
       
        public class ProvinceDB {
        public static Map<Integer,List> getProvince(){
                String sql = "select N_PROVID ,S_PROVNAME from dict_province ";
                SQLiteDatabase db = null;
                Cursor c = null;
                 Map<Integer,List> provinceData = new HashMap<Integer,List>();
                List provinceList = null;
                try{
                        db = DatabaseHelper.getDatabase();
                        c = db.rawQuery(sql, null);
                        List provinceList1 = new ArrayList();
                        List provinceList2 = new ArrayList();
                        while(c.moveToNext()){
                                Map provinceMap = new HashMap();
                                provinceMap.put(c.getString(1), c.getInt(0));
                                provinceList1.add(provinceMap);
                                provinceList2.add(c.getString(1));
                        }
                        provinceData.put(0, provinceList1);
                        provinceData.put(1, provinceList2);
                }catch(Exception e){
                        e.printStackTrace();
                }finally{
                        if(c!=null){
                                c.close();
                        }
                        if(db!=null){
                                db.close();
                        }
                }
                return provinceData;
        }
       
        public static List<String> getCityByPid(int id){
                String sql = "select S_CITYNAME  from dict_city where N_PROVID= "+id;
                SQLiteDatabase db = null;
                Cursor c = null;
                List<String> cityList = null;
                try{
                        db = DatabaseHelper.getDatabase();
                        c = db.rawQuery(sql, null);
                        cityList = new ArrayList<String>();
                        while(c.moveToNext()){
                                cityList.add(c.getString(0));
                        }
                }catch(Exception ex){
                        ex.printStackTrace();
                }finally{
                        if(c!=null){
                                c.close();
                        }
                        if(db!=null){
                                db.close();
                        }
                }
                return cityList;
               
        }
}


3.test_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent" android:layout_height="fill_parent"
        android:orientation="vertical">

        <LinearLayout android:layout_width="fill_parent"
                android:layout_height="wrap_content">
                <Spinner android:id="@+id/sp_bslProvice" android:layout_width="wrap_content"
                        android:layout_height="wrap_content" android:layout_weight="1" />
                <Spinner android:id="@+id/sp_bslCity" android:layout_width="wrap_content"
                        android:layout_height="wrap_content" android:layout_weight="1" />
        </LinearLayout>

Android利用Spinner从数据库中读取数据并实现2级互动

package org.jian.database; import android.content.Context; import android.database.sqlite.SQLiteDat...
  • u012356022
  • u012356022
  • 2014年05月13日 20:43
  • 2131

ajax写级联效果,动态从数据库获取数据

要实现的级联数据的效果是,咨询方式有多种,有的有子咨询方式,有的没有,直接上图图一中选择自选方式,例如:选择面询,效果如图二,后面对应的有面询的子咨询方式,有的没有子咨询方式,如图三,没有子咨询方式,...
  • sunping177
  • sunping177
  • 2016年09月08日 16:56
  • 1442

数据库动态加载省市区信息,实现三级联动

本文转载自:http://my.oschina.net/zhengweishan/blog/402483 摘要 动态的从数据库加载全国省市区,后台使用的是SpringMvc,前台使用的是boo...
  • zhouzhiwengang
  • zhouzhiwengang
  • 2016年07月06日 10:50
  • 5051

Android利用Spinner从数据库中读取数据并实现2级互动

package org.jian.database; import android.content.Context; import android.database.sqlite.SQLiteDat...
  • u012356022
  • u012356022
  • 2014年05月13日 20:43
  • 2131

spinner 从数据库读取数据并实现二级联动。 .

这里主要实现了。省份和城市的二级关联。选择省份。二级对应的就是省份所有的城市 下面看代码;         1.activity         @Override         ...
  • liujianminghero
  • liujianminghero
  • 2012年04月22日 21:45
  • 1232

Ajax实现从数据库读取数据后,实现分页

Ajax实现从数据库读取数据后,实现分页的操作: 1、 分页效果如图所示:   首先写一个分页的类。 Page.java 在里面封装 了总页数,当前页,总记录数。 2、 在servlet...
  • smallsundoudou
  • smallsundoudou
  • 2012年02月27日 15:53
  • 2059

从HBase数据库表中读取数据动态转为DataFrame格式,方便后续用Spark SQL操作(scala实现)

个人研究后,才发现HBase存储的都是字符串类型,大部分函数都是byte[]字节类型来操作,需要用到HBaseTableCatalog类,需要导入hbase-spark-***.jar相关jar包,下...
  • ZhouyuanLinli
  • ZhouyuanLinli
  • 2017年06月01日 20:39
  • 1658

网页实现从数据库读取数据并简单分页

大致的思想就是:   1.设置每页要显示的最大记录数。   2.计算出页面总数   3.当前页面跟总页面数比较改变连接的状态   4.用limit控制从数据库中...
  • qq_17121501
  • qq_17121501
  • 2016年03月26日 01:20
  • 508

基于JDBC从数据库中读取数据,在百度地图批量标注地点例程

  • 2017年10月18日 22:27
  • 4KB
  • 下载

C# 从串口读取数据并保存到ACCESS数据库中

  • 2015年06月07日 17:15
  • 159KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Spinner 从数据库中读取数据并实现2级互动
举报原因:
原因补充:

(最多只允许输入30个字)