Android Sqlite 代码实现 多表联合查询

最近开发ServerMonitor解决的一个issue,关于数据库的的升级,需要log表内添加一个is_scuuess字段并且对原数据库中每条日志的该记录赋值,判断成功的逻辑是根据不同协议的返回状态码及请求时间进行判断,因为日志表内只有一个site_id字段,具体日志记录的协议类型字段在site表内,于是决定采用多表联合查询的方法,通过site_id,将log表的日志记录与site表内的port_type一同查询出来 然后通过moveToNext()方法对每一条日志进行处理,具体核心代码是:

      Cursor cursorSite_log = db.rawQuery(" SELECT x.*, y.port_type FROM log x, site y "+
                "WHERE x.site_id = y._id",null);

需要在创建一个Log_siteInfo类包含log表内的所有字段和site表的port_type字段 :

  public Log_siteInfo(Cursor cursorSite_log) {
     this.port_type=cursorSite_log.getString(cursorSite_log.getColumnIndex("port_type"));
     ......
  }

然后在

      try {
             while (cursorSite_log != null && cursorSite_log.moveToNext()){
                   Log_siteInfo log_siteInfo = new Log_siteInfo(cursorSite_log);
                    //具体执行代码
                   }
        }finally {
            if (cursorSite_log != null) {
                cursorSite_log.close();
            }
        }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值