一起来开发Android的天气软件(二)——使用LitePal搭建数据库

这篇博客介绍了如何在Android天气应用中使用LitePal框架搭建SQLite数据库,包括Province、City、County三张表的创建,阐述了多对一的关系,并展示了如何进行对象关系映射及数据库操作。
摘要由CSDN通过智能技术生成

      谢谢大家对该系列博文的支持与关注,我们现在趁热打铁正式开始我们的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类!

import java.util.ArrayList;  
import java.util.List;  
  
import org.litepal.crud.DataSupport;  
  
public class Province extends DataSupport {  
    private int id;  
    private String province_name;  
  
    private String province_code;  
  
    private List<City> cities = new ArrayList<City>();  
  
    public String getProvince_code() {  
        return province_code;  
    }  
  
    public void setProvince_code(String province_code) {  
        this.province_code = province_code;  
    }  
  
    public List<City> getCities() {  
  
        return cities;  
    }  
  
    public void setCities(List<City> cities) {  
        this.cities = cities;  
    }  
  
    public int getId() {  
        return id;  
    }  
  
    public void setId(int id) {  
        this.id = id;  
    }  
  
    public String getProvince_name() {  
        return province_name;  
    }  
  
    public void setProvince_name(String province_name) {  
        this.province_name = province_name;  
    }  
  
}

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

import java.util.ArrayList;  
import java.util.List;  
  
import org.litepal.crud.DataSupport;  
  
public class City extends DataSupport {  
    private int id;  
    private String city_name;  
    private String city_code;  
    private Province province;  
      
    private List<County> counties = new ArrayList<County>();  
  
    public List<County> getCounties() {  
  
        return counties;  
    }  
  
    public void setCounties(List<County> counties) {  
        this.counties = counties;  
    }  
  
    public int getId() {  
        return id;  
    }  
  
    public void setId(int id) {  
        this.id = id;  
    }  
  
    public String getCity_name() {  
        return city_name;  
    }  
  
    public void setCity_name(String city_name) {  
        this.city_name = city_name;  
    }  
  
    public String getCity_code() {  
        return city_code;  
    }  
  
    public void setCity_code(String city_code) {  
        this.city_code = city_code;  
    }  
  
    public Province getProvince() {  
        return province;  
    }  
  
    public void setProvince(Province province) {  
        this.province = province;  
    }  
  
}

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

   同上County表如下就好了!

   

[java]  view plain copy
  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;  
  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值