当前位置: 代码迷 >> java >> MapDB并行创建地图
  详细解决方案

MapDB并行创建地图

热度:94   发布时间:2023-08-04 09:31:00.0

我正在使用MapDB创建并行Maps-想知道它是否安全以及是否可以通过更好的方式完成。 还假设每个销售表查询都可以产生上百万条记录。

public static void main(String[] args){
        DB db = DBMaker.newFileDB("mapdbFile").transactionDisable().mmapFileEnablePartial().make();
        getEmployees().parallelStream().forEach(e -> createRecords(e, db));
    }

private static List<Employee> getEmployees(){
    /* return employees list */
}

private static void createRecords(Employee employee, DB db) {
    JdbcTemplate template = /* spring JdbcTemplate creation */
    String query = "select name from sales where emp_id = "+employee.getId();        
    final BTreeMap<String, Long> map = db.createTreeMap("Employee" + employee.getId())
            .nodeSize(32).comparator(String.CASE_INSENSITIVE_ORDER).make();
    template.query(query, rs -> {
        put(map, rs.getString("product_name"), rs.getLong("sales"));
    });
}

数据库对象已同步并且是线程安全的。 因此,是的,并行地图创建是安全的。

  相关解决方案