一起来开发Android的天气软件(二)

来源:网络转载 责任编辑:张俊
默认
特大
宋体
黑体
雅黑
楷体

      谢谢大家对该系列博文的支持与关注,我们现在趁热打铁正式开始我们的Android天气软件的开发吧!没有阅读过之前关于该软件的功能需求的同学可以先看一下 一起来开发Android的天气软件(一),可以先去快速浏览一下,清楚我们的概要体系。今天我们要做的是搭建Sqlite数据库,那这个数据库要存储哪些信息呢!该数据库是用来存储全国的省市县的一些信息,全国共有34个省比如浙江旗下又有好多的市如杭州、温州、湖州,杭州下面又有很多区县,我们要做的就是把这些结构化的数据存储到我们的数据库中。

     那么我们现在就开始吧!我们这次使用的是LitePal的开源框架,它采用了对象关系映射(ORM)的模式,并将我们平时开发时最常用到的一些数据库功能进行了封装,使得不用编写一行SQL语句就可以完成各种建表、増删改查的操作。用起来总之非常的方便,从郭霖大神的博文中学会了解该框架后,我就快速学以致用用到这个天气软件的编程中来,Pratiece makes preferct,我们下面就来见识下LitePal的威力!

    首先我们先要建立Province,City,County三张表。

    1、Province


    2、City


    3、County


    好的,以上这是我们表的结构的庐山真面目,我们会发现每一张表都会有一个id,然后会有相应的province_code,province_name属性,除此之外呢,city还有一个province_id列,这是一个外键列,是为了实现省份表与城市表的一个关联关系,一个city表里面存放一个具体的省份id,并且允许多个城市都存放同一个省份id,这样一个城市就只能对应一个省份,但一个省份却可以有多个城市,也就实现多对一的关系了!以此类推,county也有一个city_id来实现市与县的一对多的关系,不知道大家看到这里都理清楚了没有我们三张表的关系呢!


      我们知道了以上的表结构,我们可以正式进入建表操作了,这边我在重新简述一下使用LitePal的使用流程,如果还没有下载这个Jar包的同学,LitePal开源项目地址:https://github.com/LitePalFramework/LitePal下载一下,首先在自己的程序导入Jar包,在在该项目的assets目录下面新建一个litepal.xml文件,第三步再在AndroidManifest.xml中配置一下LitePalApplication了,三步就完成了该包的导入过程!

      使用LitePal后呢,我们就不用"create table province (" + "id integer primary key autoincrement, " + "province_name varchar, " + "province_code varchar " )";这样的建表语句了,一切变得很简单。根据对象关系映射模式的理念,每一张表都应该对应一个模型(Model),也就是说,如果我们需要先建一张Provinces表,就应该有一个对应的Province模型类。需要什么表建立一个相应的类,里头有什么列就在模型类里对应怎样的字段,让我们看一下!Provinces类!

[java] view plain copy

  1. import java.util.ArrayList;    
  2. import java.util.List;    
  3.     
  4. import org.litepal.crud.DataSupport;    
  5.     
  6. public class Province extends DataSupport {    
  7.     private int id;    
  8.     private String province_name;    
  9.     
  10.     private String province_code;    
  11.     
  12.     private List<City> cities = new ArrayList<City>();    
  13.     
  14.     public String getProvince_code() {    
  15.         return province_code;    
  16.     }    
  17.     
  18.     public void setProvince_code(String province_code) {    
  19.         this.province_code = province_code;    
  20.     }    
  21.     
  22.     public List<City> getCities() {    
  23.     
  24.         return cities;    
  25.     }    
  26.     
  27.     public void setCities(List<City> cities) {    
  28.         this.cities = cities;    
  29.     }    
  30.     
  31.     public int getId() {    
  32.         return id;    
  33.     }    
  34.     
  35.     public void setId(int id) {    
  36.         this.id = id;    
  37.     }    
  38.     
  39.     public String getProvince_name() {    
  40.         return province_name;    
  41.     }    
  42.     
  43.     public void setProvince_name(String province_name) {    
  44.         this.province_name = province_name;    
  45.     }    
  46.     
  47. }  

   以上就是我们的Provinces类,我们可以看到该模型类中有id,province_name,provice_code以及cities字段,并且都实现了其中的get set方法,这边要注意一定要实现getset方法的,要不然建表会失败的!此外,id属性可写可不写,LitePal都会和人性化的自动生成的,重点在我们这边有一个CITY的集合,这个是干什么的呢,就是用来描述一个province对应着多个city,所以建立了一个list集合,那么在city表又怎么表示多对一的关系呢!

[java] view plain copy

  1. import java.util.ArrayList;    
  2. import java.util.List;    
  3.     
  4. import org.litepal.crud.DataSupport;    
  5.     
  6. public class City extends DataSupport {    
  7.     private int id;    
  8.     private String city_name;    
  9.     private String city_code;    
  10.     private Province province;    
  11.         
  12.     private List<County> counties = new ArrayList<County>();    
  13.     
  14.     public List<County> getCounties() {    
  15.     
  16.         return counties;    
  17.     }    
  18.     
  19.     public void setCounties(List<County> counties) {    
  20.         this.counties = counties;    
  21.     }    
  22.     
  23.     public int getId() {    
  24.         return id;    
  25.     }    
  26.     
  27.     public void setId(int id) {    
  28.         this.id = id;    
  29.     }    
  30.     
  31.     public String getCity_name() {    
  32.         return city_name;    
  33.     }    
  34.     
  35.     public void setCity_name(String city_name) {    
  36.         this.city_name = city_name;    
  37.     }    
  38.     
  39.     public String getCity_code() {    
  40.         return city_code;    
  41.     }    
  42.     
  43.     public void setCity_code(String city_code) {    
  44.         this.city_code = city_code;    
  45.     }    
  46.     
  47.     public Province getProvince() {    
  48.         return province;    
  49.     }    
  50.     
  51.     public void setProvince(Province province) {    
  52.         this.province = province;    
  53.     }    
  54.     
  55. }  

    从以上看出,我们只要在city表建立一个Province类就好了,表示每一个city都对应着一个Province归属,好的说到这里大家都应该明白怎么实现了吧!细心的朋友还会发现我们每一个类还继承了一个DateSupport,这个类是为了实现LitePal数据库的增删改查操作的哈!

   同上County表如下就好了!

   

[java] view plaincopy
  1. package com.melhc.model;  
  2.   
  3. import org.litepal.crud.DataSupport;  
  4.   
  5. public class County extends DataSupport {  
  6.     private int id;  
  7.     private String county_name;  
  8.     private String county_code;  
  9.     private City city;  
  10.   
  11.     public int getId() {  
  12.         return id;  
  13.     }  
  14.   
  15.     public void setId(int id) {  
  16.         this.id = id;  
  17.     }  
  18.   
  19.     public String getCounty_name() {  
  20.         return county_name;  
  21.     }  
  22.   
  23.     public void setCounty_name(String county_name) {  
  24.         this.county_name = county_name;  
  25.     }  
  26.   
  27.     public String getCounty_code() {  
  28.         return county_code;  
  29.     }  
  30.   
  31.     public void setCounty_code(String county_code) {  
  32.         this.county_code = county_code;  
  33.     }  
  34.   
  35.     public City getCity() {  
  36.         return city;  
  37.     }  
  38.   
  39.     public void setCity(City city) {  
  40.         this.city = city;  
  41.     }  
  42.   
  43. }   
     好的,通过以上操作我们就完成了三张表的建立,别忘了一件事在assets文件的litepal.xml文件修改

 

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <litepal>  
  3.   
  4.     <dbname value="weather" >  
  5.     </dbname>  
  6.   
  7.     <version value="2" >  
  8.     </version>  
  9.   
  10.     <list>  
  11.   
  12.         <mapping class="com.melhc.model.Province" >  
  13.         </mapping>  
  14.   
  15.         <mapping class="com.melhc.model.City" >  
  16.         </mapping>  
  17.   
  18.         <mapping class="com.melhc.model.County" >  
  19.         </mapping>  
  20.     </list>  
  21.   
  22. </litepal>  

    OK,下面为了方便我们的数据库操作,我们在封装一个   WeatherDB类,实现对数据库的正式生成和增删改查操作!

[java] view plaincopy

  1. <span style="font-family:Microsoft YaHei;font-size:14px;">  /** 
  2.      * 将provice实例存储到数据库 
  3.      */  
  4.     public void saveProvice(Province province) {  
  5.         if (province != null) {  
  6.             province.save();  
  7.         }  
  8.     }</span>  

     我们可以看到在存储province的信息时,该方法只要传入一个province类,然后调用province.save方法就可以实现数据库的插入,那么怎么插入数据库这些字段的呢,我们只要先新建一个province类,然后再把网络读取的信息通过province.setProvice_name()等set方法传入即可了,是不是非常简单呢!Province province = new Province();province.setProvince_code(array[0]); province.setProvince_name(array[1]);

   那么下面问题又来了我们怎么实现city与Province的表与表之间的关联关系呢,其实也非常简单,只要将city对应的province得到,并用set方法构造进入就好了!我们来看一下

[java] view plaincopy

  1.                     City city = new City();  
  2.                     city.setCity_code(array[0]);  
  3.                     city.setCity_name(array[1]);  
  4.                     city.setProvince(province);  
  5.                     weatherDB.saveCity(city);</span>  
    是不是非常简单呢!那么如何读取呢,这个就更简单了,建立一个Province类的list集合,调用DateSupport的findAll()方法即可得到,查询的方式还有很多,我这边就不一一列举了,你还可以增加很多查询的删选条件等等。
[java] view plaincopy
  1.  /** 
  2.      * 从数据库读取全国所有的省份信息 
  3.      */  
  4.     public List<Province> loadProvices() {  
  5.         List<Province> list = DataSupport.findAll(Province.class);  
  6.         return list;  
  7.     } 
    那么如何查询city表的数据呢?我们知道每一个城市都对应着一个省province,那么我们先通过与之关联的province_id找到它对应的province类,问题就解决一大半了,然后再通过这个province类的getCities()方法即可返回该省下面的所有城市列表!

[java] view plaincopy

  1.  /** 
  2.      * 从数据库读取某省下的所有的城市信息 
  3.      */  
  4.     public List<City> loadCities(int provinceId) {  
  5.         Province provice = DataSupport.find(Province.class, provinceId,true);  
  6.         List<City> list = provice.getCities();  
  7.   
  8.         return list;  
  9.     }
     好的关键点都解释完了,我们来看一下这个类的全貌吧!

[java] view plaincopy

  1. package com.melhc.db;  
  2.   
  3. import java.util.List;  
  4.   
  5. import org.litepal.crud.DataSupport;  
  6. import org.litepal.tablemanager.Connector;  
  7.   
  8. import com.melhc.model.City;  
  9. import com.melhc.model.County;  
  10. import com.melhc.model.Province;  
  11.   
  12. import android.database.sqlite.SQLiteDatabase;  
  13.   
  14. public class WeatherDB {  
  15.     /** 
  16.      * 一些基本的数据库方法封装 
  17.      */  
  18.     private SQLiteDatabase db;  
  19.   
  20.     private static WeatherDB weatherDB;  
  21.   
  22.     public WeatherDB() {  
  23.         // TODO Auto-generated constructor stub  
  24.         db = Connector.getDatabase();//正式生成数据库  
  25.     }  
  26.   
  27.     public synchronized static WeatherDB getInstance() {  
  28.         if (weatherDB == null) {  
  29.             weatherDB = new WeatherDB();  
  30.         }  
  31.         return weatherDB;  
  32.     }  
  33.   
  34.     /** 
  35.      * 将provice实例存储到数据库 
  36.      */  
  37.     public void saveProvice(Province province) {  
  38.         if (province != null) {  
  39.             province.save();  
  40.         }  
  41.     }  
  42.   
  43.     /** 
  44.      * 从数据库读取全国所有的省份信息 
  45.      */  
  46.     public List<Province> loadProvices() {  
  47.         List<Province> list = DataSupport.findAll(Province.class);  
  48.         return list;  
  49.     }  
  50.   
  51.     /** 
  52.      * 将city实例存储到数据库 
  53.      */  
  54.     public void saveCity(City city) {  
  55.         if (city != null) {  
  56.             city.save();  
  57.         }  
  58.     }  
  59.   
  60.     /** 
  61.      * 从数据库读取某省下的所有的城市信息 
  62.      */  
  63.     public List<City> loadCities(int provinceId) {  
  64.         Province provice = DataSupport.find(Province.class, provinceId,true);  
  65.         List<City> list = provice.getCities();  
  66.   
  67.         return list;  
  68.     }  
  69.   
  70.     /** 
  71.      * 将county实例存储到数据库 
  72.      */  
  73.     public void saveCounty(County county) {  
  74.         if (county != null) {  
  75.             county.save();  
  76.         }  
  77.     }  
  78.   
  79.     /** 
  80.      * 从数据库读取某城市下的所有的县信息 
  81.      */  
  82.     public List<County> loadCounties(int cityId) {  
  83.         City city = DataSupport.find(City.class, cityId,true);  
  84.         List<County> list = city.getCounties();  
  85.         return list;  
  86.     }  
  87.   
  88.     /** 
  89.      * 关闭数据库 
  90.      */  
  91.     public void destroyDB() {  
  92.         if (db != null) {  
  93.             db.close();  
  94.         }  
  95.     }  
  96.   
  97. }

        好的,这一节课的内容就讲到这里,第一次博文码那么多字,感觉萌萌哒啊,希望大家通过这篇博文能对LitePaL框架有一个更好的认识,也希望大家能继续支持该系列的博文,你们的支持是我写下去的最大动力!今天的数据库设计就到此结束,下一篇博文

一起来开发Android的天气软件(三)

       下面是该应用的Git开源地址,https://github.com/melhc/SimpleWeather

       2014博客之星请支持一下啊!http://vote.blog.csdn.NET/blogstar2014/details?username=u013900875#content

有哪个比较实用且简洁的 Android 天气 App

答:首推彩虹天气国人开发,与墨迹天气使用同一个天气源,该有的功能基本都有,但是整个软件只有不到500k,简单小巧,预报较为准确,无广告。缺点就是插件皮肤略显屌丝,可供选择的皮肤较少,而且桌面插件不支持快捷操作。墨迹天气应该是目前国内天...

有哪个比较实用且简洁的 Android 天气 App

答:首推彩虹天气 国人开发,与墨迹天气使用同一个天气源,该有的功能基本都有,但是整个软件只有不到500k,简单小巧,预报较为准确,无广告。缺点就是插件皮肤略显屌丝,可供选择的皮肤较少,而且桌面插件不支持快捷操作。 墨迹天气 应该是目前国内...

有哪些比较实用且简洁的 Android 天气 App

答:首推彩虹天气 国人开发,与墨迹天气使用同一个天气源,该有的功能基本都有,但是整个软件只有不到500k,简单小巧,预报较为准确,无广告。缺点就是插件皮肤略显屌丝,可供选择的皮肤较少,而且桌面插件不支持快捷操作。 墨迹天气 应该是目前国内...

​android软件开发:中国气象局api接口(显示...

答:中国国家气象局天气预报接口总共提供了三个: http://www.weather.com.cn/data/sk/101010100.html http://www.weather.com.cn/data/cityinfo/101010100.html http://m.weather.com.cn/data/101010100.html 最详细的信息来自第三个接口。上面url...

推荐一款准确而全面的天气APP软件安卓版的??

答:墨迹天气,全球约5亿人在使用的天气APP,支持196个国家70多万个城市及地区的天气查询,分钟级、公里级天气预报,实时预报雨雪。提供15天天气预报,5天空气质量预报,实时空气质量及空气质量等级预报。特殊天气提前发送预警信息,帮助用户更好做...

想用android写一个类似小米4自带天气程序的应用,...

答:连击Android版,米4是进不了开发都模式的。只有点击下面的“版本号”才行 答题不易,互相帮助,手机提问的朋友在客户端右上角评价点满意即可. 如认可我的回答,请点击采纳为满意回答按钮.

安卓天气软件哪个好,安卓天气软件

答:安卓系统的手机的时候,可以用墨迹天气,天气通等等软件就可以的。 想用哪个软件的时候直接在应用宝里面就可以下载的。 上面的软件自己都是经过系统的审核,都是正式版本的软件。 不会自己出现什么不兼容或者冲突的问题,是没有携带病毒和广告的...

我模仿别人开发了一个安卓天气预报的软件,这种水...

答:找的到。 带着你的软件和自信就可以了。

安卓上什么天气软件最好用呢

答:最好用的天气软件就是墨迹天气和天气通了。 墨迹天气是一款界面华丽并且实用的免费天气信息查询软件,兼容塞班S60 V2版、S60 V3版、S60 V5版以及Android几乎全系列手机。支持国内2488个城市的天气源,是中国支持城市最多的手机天气预报软件,并...

安卓开发如何获取天气API

答:可以看一下这个,看能否对你有所帮助。 Android开发_android如何通过Google Weather Api 获取天气预报 信息 来源百度文库:http://wenku.baidu.com/view/68815ab5fd0a79563c1e7254.html

为您准备的相关内容:

  • Android 简易版天气预报app的现实(2)
  • struts2 doubleselect
  • Super natural oxygen bar in E China
  • EF实体框架之CodeFirst六
  • .net(c#)提取多层嵌套的JSON
  • 用Digester解析xml到bean
  • axis部署WS---传递复杂类型
  • fastJson在java后台转换json格式数据探究...
  • >>> 温馨提示:您还可以点击下面分页查看更多相关内容 <<<

    头条

    热门

    24小时热评

    热点排行榜

    Copyright ? 2012-2016 tuxi.com.cn 版权所有 京ICP备10044368号 京公网安备11010802011102号 关于我们 | 广告服务 | 诚聘英才 | 联系我们 | 友情链接 | 免责申明