add mysql
parent
80fa243b07
commit
3dcae5e8dc
@ -0,0 +1,8 @@
|
||||
package com.rehome.mqttclienttemperature.service;
|
||||
|
||||
import com.rehome.mqttclienttemperature.dto.ResponseDto;
|
||||
import com.rehome.mqttclienttemperature.entity.Temperature;
|
||||
|
||||
public interface MysqlTemperatureService {
|
||||
ResponseDto saveTemperature(Temperature temperature);
|
||||
}
|
||||
@ -0,0 +1,78 @@
|
||||
package com.rehome.mqttclienttemperature.service.impl;
|
||||
|
||||
import com.google.gson.Gson;
|
||||
import com.rehome.mqttclienttemperature.datasource.DataSource;
|
||||
import com.rehome.mqttclienttemperature.dto.ResponseDto;
|
||||
import com.rehome.mqttclienttemperature.entity.Temperature;
|
||||
import com.rehome.mqttclienttemperature.service.MysqlTemperatureService;
|
||||
import com.rehome.mqttclienttemperature.service.OracleTemperatureService;
|
||||
import com.rehome.mqttclienttemperature.service.PostgresSqlTemperatureService;
|
||||
import com.rehome.mqttclienttemperature.service.SqlServerTemperatureService;
|
||||
import com.rehome.mqttclienttemperature.utils.JdbcUtil;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.stereotype.Service;
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.CompletableFuture;
|
||||
import java.util.concurrent.ExecutorService;
|
||||
import java.util.concurrent.Executors;
|
||||
|
||||
@Slf4j
|
||||
@Service
|
||||
|
||||
public class MysqlTemperatureServiceImpl implements MysqlTemperatureService {
|
||||
public static DataSource ds = new DataSource();
|
||||
static {
|
||||
//配置数据源
|
||||
ds.setId("3306");
|
||||
ds.setName("mysql");
|
||||
ds.setUrl("jdbc:mysql://192.168.3.9:3306/appserver?useUnicode=true&characterEncoding=utf-8&useSSL=false&autoReconnect=true");
|
||||
ds.setUsername("root");
|
||||
ds.setPassword("Skyinno251,");
|
||||
ds.setDriver("com.mysql.cj.jdbc.Driver");
|
||||
}
|
||||
|
||||
@Override
|
||||
public ResponseDto saveTemperature(Temperature temperature) {
|
||||
// 自定义一个线程池,内部包含8个线程
|
||||
ExecutorService customPool = Executors.newFixedThreadPool(2);
|
||||
CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {
|
||||
//SYSTIMESTAMP
|
||||
//CURRENT_TIMESTAMP
|
||||
//HIBERNATE_SEQUENCE
|
||||
//temperature_seq_appserver
|
||||
String sql = "insert into temperature(temperature, humidity, data_date, data_hour, data_minute, topic, location_desc, create_date) values(?, ?, ?, ?, ?, ?, ?, CURRENT_TIMESTAMP())";
|
||||
List<Object> jdbcParamValues = new ArrayList<>();
|
||||
|
||||
jdbcParamValues.add(temperature.getTemperature());
|
||||
jdbcParamValues.add(temperature.getHumidity());
|
||||
jdbcParamValues.add(temperature.getDataDate());
|
||||
jdbcParamValues.add(temperature.getDataHour());
|
||||
jdbcParamValues.add(temperature.getDataMinute());
|
||||
jdbcParamValues.add(temperature.getTopic());
|
||||
jdbcParamValues.add(temperature.getLocationDesc());
|
||||
//jdbcParamValues.add(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(temperature.getCreateDate()));
|
||||
|
||||
Gson gson = new Gson();
|
||||
ResponseDto responseDto = JdbcUtil.executeSql(ds, sql, jdbcParamValues);
|
||||
String dbQueryResult = gson.toJson(responseDto);
|
||||
log.info(dbQueryResult);
|
||||
jdbcParamValues.clear();
|
||||
|
||||
if(responseDto.isSuccess()){
|
||||
return "数据库同步成功";
|
||||
}
|
||||
return "数据库同步失败";
|
||||
}, customPool);
|
||||
|
||||
ResponseDto responseDto = future.thenApply(result -> {
|
||||
log.info("Result: " + result);
|
||||
if("数据库同步成功".equals(result)){
|
||||
return ResponseDto.successWithMsg(result);
|
||||
}
|
||||
return ResponseDto.fail(result);
|
||||
}).join();
|
||||
return responseDto;
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue