/**
* 同步数据信息到ES
* @return
*/
public boolean syncNhReportSeessToEs(){ long begin = System.currentTimeMillis();
logger.error("------------------开始始初始化报备带看列表数据到ES"+ DateUtil.getDefaultDate()+ "-----------------------");
//分页大小
int pageSize = 500;
int total = jdbcTemplate.queryForInt("select count(1) from (select * from nh_report nr where nr.id in(select min(nr1.id) from nh_report nr1 where nr1.record_is_deleted = 0 and nr1.city_code = 1 group by nr1.reporter_panid,nr1.customer_name,nr1.customer_phone))");
if (total == 0) {
return true;
}
logger.error("查出需要处理的报备表数据为"+total+"条");
double querySize = total;
double totalPage = Math.ceil(querySize / pageSize);
logger.error("共分" + totalPage + "页");
final String sql = "select * from(" +
"select nr.*,rownum as rn from nh_report nr where nr.id in" +
"(select min(nr1.id) from nh_report nr1" +
" where nr1.record_is_deleted = 0 and nr1.city_code = 1 group by nr1.reporter_panid, nr1.customer_name, nr1.customer_phone) and rownum <= ? )where rn>=?";
ExecutorService es = Executors.newFixedThreadPool(20);
for (int i = 0; i < totalPage; i++) {
logger.error("执行第"+i+"页");
int start = i * pageSize + 1;
int end = (i + 1) * pageSize;
if (end > total) {
end = total;
}
final Object[] params = new Object[] { end, start };
es.submit(new Runnable() {
@SuppressWarnings("unused")
@Override
public void run() {
List<Map<String, Object>> objs = new ArrayList<Map<String, Object>>();
List<ReportSeeEsModel> contants = jdbcTemplate.query(sql, params, new RowMapper() {
@Override
public ReportSeeEsModel mapRow(ResultSet rs, int i) throws SQLException {
ReportSeeEsModel model = new ReportSeeEsModel();
String id = JugHelper.generalUUID();
//主键id
model.setId(id);
model.setCityCode(String.valueOf(NhReport.CITYCODE_BEIJING));
//客户姓名
String customerName = rs.getObject("CUSTOMER_NAME") != null ? rs.getObject("CUSTOMER_NAME").toString() : "";
model.setCustomerName(customerName);
//客户姓名 不分词
model.setReporterCustomerName(customerName);
//客户电话
String customerPhone = rs.getObject("CUSTOMER_PHONE") != null ? rs.getObject("CUSTOMER_PHONE").toString() : "";
model.setCustomerPhone(customerPhone);
//客户电话,不分词
model.setReporterCustomerPhone(customerPhone);
//报备人公盘id
String reportPanId = rs.getObject("REPORTER_PANID") != null ? rs.getObject("REPORTER_PANID").toString() : "";
model.setReporterPanid(reportPanId);
//城市编码
model.setCityCode(String.valueOf(NhReport.CITYCODE_BEIJING));
//部门id
model.setDeptId(rs.getObject("DEPT_ID") != null ? rs.getObject("DEPT_ID").toString() : "");
//店组id
model.setShopId(rs.getObject("SHOP_ID") != null ? rs.getObject("SHOP_ID").toString() : "");
//大区
model.setRegionId(rs.getObject("REGION_ID") != null ? rs.getObject("REGION_ID").toString() : "");
return model;
}
}); //循环处理带看和户型大小的相关数据
for (ReportSeeEsModel reportSeeEsModel:contants
) {
String reporterPanid = reportSeeEsModel.getReporterPanid();
String customerName = reportSeeEsModel.getCustomerName();
String customerPhone = reportSeeEsModel.getCustomerPhone();
final Object[] params = new Object[] { reporterPanid,customerName,customerPhone };
//查询当前经纪人,当前客户姓名,当前客户电话相关的带看
String sql = "select * from nh_report_see nrs" +
" join nh_report nr on nr.id = nrs.report_id" +
" where nr.reporter_panid = ? and nr.customer_name = ? and nr.customer_phone = ? and nrs.see_time is not null";
List<NhReportSee> reportSees = jdbcTemplate.query(sql, params, new RowMapper() {
@Override
public NhReportSee mapRow(ResultSet rs, int i) throws SQLException {
NhReportSee reportSee = new NhReportSee();
reportSee.setReportId(rs.getObject("REPORT_ID") != null ? rs.getObject("REPORT_ID").toString() : "");
reportSee.setSeeTime(rs.getObject("SEE_TIME") != null ? (Date) rs.getObject("SEE_TIME") : null);
reportSee.setId(rs.getObject("ID") != null ? rs.getObject("ID").toString() : "");
reportSee.setStageId(rs.getObject("STAGE_ID") != null ? rs.getObject("STAGE_ID").toString() : "");
return reportSee;
}
});
//根据当前经纪人当前客户的所有报备id查询出所有的意向户型
String sql2 = "select * from nh_stage_layout nsl" +
" join nh_report_layout nrl on nsl.id = nrl.layout_id" +
" join nh_report nr on nr.id = nrl.proposer_id" +
" where nr.reporter_panid = ? and nr.customer_name = ? and nr.customer_phone = ?";
List<LayoutVo> layouts = jdbcTemplate.query(sql2, params, new RowMapper() {
@Override
public LayoutVo mapRow(ResultSet rs, int i) throws SQLException {
LayoutVo layoutVo = new LayoutVo();
layoutVo.setArea(rs.getObject("AREA") != null ? rs.getObject("AREA").toString() : "");
layoutVo.setRoomNum(rs.getObject("ROOM_NUM") != null ? rs.getObject("ROOM_NUM").toString() : "");
layoutVo.setTotalPrice(rs.getObject("TOTAL_PRICE") != null ? Integer.valueOf(rs.getObject("TOTAL_PRICE").toString()) : null);
return layoutVo;
}
});
//查询当前经纪人当前客户的所有报备
String sql3 = "select * from nh_report nr where nr.reporter_panid = ? and nr.customer_name = ? and nr.customer_phone = ? order by nr.create_date desc";
List<NhReport> reports = jdbcTemplate.query(sql3, params, new RowMapper() {
@Override
public NhReport mapRow(ResultSet rs, int i) throws SQLException {
NhReport report = new NhReport();
report.setId(rs.getObject("ID") != null ? rs.getObject("ID").toString() : "");
report.setCreateDate(rs.getObject("CREATE_DATE") != null ? (Date) rs.getObject("CREATE_DATE") : null);
return report;
}
});
//报备时间
reportSeeEsModel.setReportTime(reports.get(0).getCreateDate().toString());
String areaMax = CommonUtil.formatDouble(CommonUtil.getMaxLayoutArea(layouts)).equals("") ? "0" : CommonUtil.formatDouble(CommonUtil.getMaxLayoutArea(layouts));
String areaMin = CommonUtil.formatDouble(CommonUtil.getMinLayoutArea(layouts)).equals("") ? "0" : CommonUtil.formatDouble(CommonUtil.getMinLayoutArea(layouts));
String roomMax = CommonUtil.formatDouble(CommonUtil.getMaxLayoutHou(layouts)).equals("") ? "0" : CommonUtil.formatDouble(CommonUtil.getMaxLayoutHou(layouts));
String roomMin = CommonUtil.formatDouble(CommonUtil.getMinLayoutHou(layouts)).equals("") ? "0" : CommonUtil.formatDouble(CommonUtil.getMinLayoutHou(layouts));
String priceMax = CommonUtil.formatDouble(CommonUtil.getMaxLayoutTotalPrice(layouts)).equals("") ? "0" : CommonUtil.formatDouble(CommonUtil.getMaxLayoutTotalPrice(layouts));
String priceMin = CommonUtil.formatDouble(CommonUtil.getMinLayoutTotalPrice(layouts)).equals("") ? "0" : CommonUtil.formatDouble(CommonUtil.getMinLayoutTotalPrice(layouts));
//最大价格
reportSeeEsModel.setHouPriceMax(String.valueOf(priceMax));
//最小价格
reportSeeEsModel.setHouPriceMin(String.valueOf(priceMin));
//最大面积
reportSeeEsModel.setHouAreaMax(String.valueOf(areaMax));
//最小面积
reportSeeEsModel.setHouAreaMin(String.valueOf(areaMin));
//最大居室
reportSeeEsModel.setHouMax(String.valueOf(String.valueOf(roomMax)));
//最小居室
reportSeeEsModel.setHouMin(String.valueOf(String.valueOf(roomMin)));
//带看次数
reportSeeEsModel.setSeeCount(String.valueOf(reportSees.size()));
Set<NhReportSee> set = new TreeSet<NhReportSee>(new Comparator<NhReportSee>() {
@Override
public int compare(NhReportSee a, NhReportSee b) {
// 字符串则按照asicc码升序排序
return a.getStageId().compareTo(b.getStageId());
}
});
set.addAll(reportSees);
List<NhReportSee> list = new ArrayList<>(set);
List<ReportSeeInfoEsModel> seeinfos = new ArrayList<>();
if(!CollectionUtils.isEmpty(list)){//如果带看的条数不为0
int index = 0;
for (NhReportSee see:list
) {
if(index==2){
break;
}
ReportSeeInfoEsModel reportSeeInfoEsModel = new ReportSeeInfoEsModel(); final Object[] params1 = new Object[] { see.getReportId() };
String sql4 = "select * from nh_report nr where nr.id = ?";
NhReport nhReport = (NhReport) jdbcTemplate.queryForObject(sql4, params1, new RowMapper() {
@Override
public NhReport mapRow(ResultSet rs, int i) throws SQLException {
NhReport nhReport = new NhReport();
nhReport.setId(rs.getObject("ID") != null ? rs.getObject("ID").toString() : "");
nhReport.setIsCustomerA(rs.getObject("IS_CUSTOMER_A") != null ? Integer.valueOf(rs.getObject("IS_CUSTOMER_A").toString()) : null);
nhReport.setIsFirstVisit(rs.getObject("IS_FIRST_VISIT") != null ? Integer.valueOf(rs.getObject("IS_FIRST_VISIT").toString()) : null);
nhReport.setIsEffective(rs.getObject("IS_EFFECTIVE") != null ? Integer.valueOf(rs.getObject("IS_EFFECTIVE").toString()) : null);
nhReport.setAuditStatus(rs.getObject("AUDIT_STATUS") != null ? Integer.valueOf(rs.getObject("AUDIT_STATUS").toString()) : null);
nhReport.setIntentionStageId(rs.getObject("INTENTION_STAGE_ID") != null ? rs.getObject("INTENTION_STAGE_ID").toString() : "");
nhReport.setPerformanceId(rs.getObject("PERFORMANCE_ID") != null ? rs.getObject("PERFORMANCE_ID").toString() : "");
return nhReport;
}
}); //是否是A类
reportSeeInfoEsModel.setIsCustomerA(String.valueOf(nhReport.getIsCustomerA()));
//是否是首访
reportSeeInfoEsModel.setIsFirstVisit(String.valueOf(nhReport.getIsFirstVisit()));
//报备id
reportSeeInfoEsModel.setReportId(nhReport.getId());
//带看时间
reportSeeInfoEsModel.setSeeDate(see.getSeeTime());
//认购时间和草签时间
if(StringUtils.isNotBlank(nhReport.getPerformanceId())){
final Object[] params2 = new Object[] { see.getReportId() };
String sql5 = "select * from nh_sale_performance nsp where nsp.report_id = ?";
NhSalePerformance performance = (NhSalePerformance) jdbcTemplate.queryForObject(sql5, params2, new RowMapper() {
@Override
public NhSalePerformance mapRow(ResultSet rs, int i) throws SQLException {
NhSalePerformance performance = new NhSalePerformance();
performance.setId(rs.getObject("ID") != null ? rs.getObject("ID").toString() : "");
performance.setBuyDate(rs.getObject("BUY_DATE") != null ? (Date)rs.getObject("BUY_DATE") : null);
performance.setDraftDate(rs.getObject("DRAFT_DATE") != null ? (Date)rs.getObject("DRAFT_DATE") : null);
return performance;
}
});
if(performance.getBuyDate()!=null){
reportSeeInfoEsModel.setBuyDate(performance.getBuyDate());
}
if(performance.getDraftDate()!=null){
reportSeeInfoEsModel.setDraftDate(performance.getDraftDate());
}
}
//带看id
reportSeeInfoEsModel.setSeeId(see.getId());
//是否有效
reportSeeInfoEsModel.setIsEffective(String.valueOf(nhReport.getIsEffective()));
//审核状态
reportSeeInfoEsModel.setAuditStatus(String.valueOf(nhReport.getAuditStatus()));
//楼盘id
reportSeeInfoEsModel.setStageId(nhReport.getIntentionStageId());
NhStage stage = nhStageIService.findById(nhReport.getIntentionStageId());
if(stage!=null){
//楼盘名称
reportSeeInfoEsModel.setStageName(stage.getStageName());
}
seeinfos.add(reportSeeInfoEsModel);
index++;
}
}
reportSeeEsModel.setSeeInfo(seeinfos);
}
for (ReportSeeEsModel model : contants) {
try {
objs.add(objectToMap(model));
} catch (Exception e) {
e.printStackTrace();
}
}
if(objs.size()>0){
logger.error("本次插入数据"+objs.size()+"条");
String result = ESClient.batchInsert(ESContant.NEWHOUSECUSTOMER_INDEX, ESContant.REPORTCUSTOMER_TYPE, objs);
logger.error(result);
} }
});
}
es.shutdown();
try {
boolean loop = true;
do { //等待所有任务完成
loop = !es.awaitTermination(2, TimeUnit.SECONDS); //阻塞,直到线程池里所有任务结束
} while (loop);
} catch (Exception e) {
e.printStackTrace();
}
logger.error("------------------结束初始化报备带看列表数据到ES"+ DateUtil.getDefaultDate()+ "-----------------------");
return true;
}

多线程分页处理批量数据--jdbc方式的更多相关文章

  1. Python多线程爬虫与多种数据存储方式实现(Python爬虫实战2)

    1. 多进程爬虫 对于数据量较大的爬虫,对数据的处理要求较高时,可以采用python多进程或多线程的机制完成,多进程是指分配多个CPU处理程序,同一时刻只有一个CPU在工作,多线程是指进程内部有多个类 ...

  2. ORACLE 分页 java 用jdbc方式以 sys账号连接oracle数据的问题

    2,3,4,6,8   betwenen 为闭区间,前后都包括 select * from(select a.*,rownum rn from (select * from student) a ) ...

  3. JAVA多线程提高四:多个线程之间共享数据的方式

    多个线程访问共享对象和数据的方式 如果每个线程执行的代码相同,可以使用同一个Runnable对象,这个Runnable对象中有那个共享数据,例如,买票系统就可以这么做. 如果每个线程执行的代码不同,这 ...

  4. fetch bulk collect into 进行批量、快速提取数据的方式

    1.游标的含义 2.oracle 11g 中的三类游标的使用方式 3.oracle 11g中使用 fetch ... bulk collect into 进行批量.快速提取数据的方式 4.根据不同情况 ...

  5. java多线程与线程并发五:多个线程访问共享对象和数据的方式

    本节的内容主要是对前面几节提到的线程间共享数据的方式做一个总结. 线程之间共享数据有以下几种方式: 1.如果每个线程执行的代码相同,可以使用同一个Runnable对象. 2.如果每个线程执行的代码不同 ...

  6. JAVA多线程学习八-多个线程之间共享数据的方式

    多个线程访问共享对象和数据的方式 如果每个线程执行的代码相同,可以使用同一个Runnable对象,这个Runnable对象中有那个共享数据,例如,买票系统就可以这么做. 如果每个线程执行的代码不同,这 ...

  7. Android编程中的5种数据存储方式

    Android编程中的5种数据存储方式 作者:牛奶.不加糖 字体:[增加 减小] 类型:转载 时间:2015-12-03我要评论 这篇文章主要介绍了Android编程中的5种数据存储方式,结合实例形式 ...

  8. 2017.11.12 web中JDBC 方式访问数据库的技术

    JavaWeb------ 第四章 JDBC数据库访问技术 在JavaWeb应用程序中数据库访问是通过Java数据库连接(JavaDateBase Connectivity简称JDBC)数据库的链接一 ...

  9. Spark JDBC方式连接MySQL数据库

    Spark JDBC方式连接MySQL数据库 一.JDBC connection properties(属性名称和含义) 二.spark jdbc read MySQL 三.jdbc(url: Str ...

随机推荐

  1. Zookeeper配置安装

    单机模式: 1:修改hosts文件 ​ 2:下载解压zookeeper.tar文件 3:创建data目录和logs目录 进入zookeeper目录下创建 ​ 4:复制一份zoo_sample.cfg配 ...

  2. oj.zstu 4421交税(合数分解成素数)

    题目 题意:T组,每一组输入一个数X,  求X最少能分成几个素数的和,输出. 思路: 对于一个大于2的偶数,由哥德巴赫猜想,一定能分成2个素数. 对于一个奇数来说,一定能分成2个或者3个素数之和.如果 ...

  3. centos中python2.7被覆盖,yum,python重新安装

    参考如下,问题以解决,绝对有效 下载链接yum和python2.7网盘 链接:https://pan.baidu.com/s/1sC2crFW1I8F7zndJU0jjcA 提取码:5kia 直接参考 ...

  4. 记录 ubuntu 安装中文语言出现 software database is broken

    在终端下执行 sudo apt-get install  language-pack-zh-han* 然后去语言中心设置中文,并全局使用即可.

  5. 前端面试:Vue.js常见的问题

    摘自今日头条用户:代码开发 原文链接: https://www.toutiao.com/a6683120112255369732/?tt_from=mobile_qq&utm_campaign ...

  6. [ARIA] Accessible modal dialogs

    Learn how to create a modal dialog with accessible keyboard and screen reader mechanics using the na ...

  7. sqlserver内存、会话、连接查询

    1.连接查询 select * from sysprocesses where dbid in (select dbid from sysdatabases where name='dbname') ...

  8. 008_硬件基础电路_RC消火花电路分析方法和思路

    如上图所示是一种RC消火花电路.电路中,+V是直流工作电压,S1是电源开关,M是直流电机,R1和C1构成RC消火花电路. 1.电路分析需要了解火花产生的原因直流电机的内部是一个线圈结构,根据线圈的有关 ...

  9. 普通的java Ftp客户端的文件上传

    关于ftp上传文件其实并不难,但有时候面对现实的环境还是很蛋疼的,今天我就分享一下,普通的上传文件文件至FTP的方式,它满足大部分FTP,但也有特别的,下篇博客会提及到. 下面我用一个FtpUtil, ...

  10. 转,SqlServer 基础之(触发器)

    概念:   触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触 ...