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();
            }
        }

你可能感兴趣的:(android,数据库,android,sqlite)