springCloud集成tdengine(原生和mapper方式) 其一

第一种 mapper方式,原生方式在主页看第二章

一、添加pom文件

java 复制代码
		<!-- HikariCP 连接池 -->
        <dependency>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP</artifactId>
        </dependency>
        <!-- TDengine 连接器-->
        <dependency>
            <groupId>com.taosdata.jdbc</groupId>
            <artifactId>taos-jdbcdriver</artifactId>
            <version>3.5.3</version>
        </dependency>

二、在nacos中配置好数据库连接

java 复制代码
spring:
  datasource:
    url: jdbc:TAOS://localhost:6030/test
    username: root
    password: yourPassWord
    driver-class-name: com.taosdata.jdbc.TSDBDriver
    hikari:
      maximum-pool-size: 10 # 连接池最大连接数
      minimum-idle: 2       # 连接池最小空闲连接数
      idle-timeout: 30000   # 空闲连接超时时间(毫秒)
      max-lifetime: 1800000 # 连接最大存活时间(毫秒)
      connection-timeout: 30000 # 连接超时时间(毫秒)

其中test是你的database,填好你的username和password

三、如果需要,配置好配置类

java 复制代码
import com.zaxxer.hikari.HikariDataSource;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import javax.sql.DataSource;

/**
 * 如果多数据源, 可以放开这边的config代码
 */
@Configuration
public class DataSourceConfig {
    @Bean
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource() {
        return new HikariDataSource();
    }

}

四、写好model类

java 复制代码
import lombok.Data;

import java.io.Serializable;
import java.util.Date;

@Data
public class DeviceModel implements Serializable {

    // 时间 == 必须
    private Date createTime;
    // 设备名字/设备id
    private String deviceId;
    // 标签值
    private String ip;
    // 值
    private Object value;
    // 类型  
    private String valueType;
    //采集状态 
    private int status;
    // 设备名称
    private String deviceName;
    // 设备parentName
    private String deviceParentName;
    
    // int类型的value值
    private Integer intValue;
    // 布尔类型的value值
    private Boolean booleanValue;
    // 小数类型的value值
    private Float floatValue;
    private Date ts;

}

五、写好mapper接口

java 复制代码
import com.apex.iot.device.model.DeviceModel;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.*;

import java.util.List;

@Mapper
public interface DeviceMapper {

    /**
     * 根据deviceId获取设备最新的值,注意,只返回一个值
     * @param deviceId 要查询的设备id
     */
    @Select("select ts,int_value as intValue,boolean_value as booleanValue,float_value as floatValue,status,device_id as deviceId,device_name as deviceName,device_parent_name as deviceParentName,ip from device_data_super_table where device_id = #{deviceId} order by ts desc limit 1")
    DeviceModel getDeviceNewMsgByDeviceId(@Param("deviceId") String deviceId );

    @Insert({
            "<script>",
            "INSERT INTO ",
            "<foreach collection='deviceList' item='data' separator=','>",
            "#{data.deviceId} using #{superTable} tags(#{data.deviceId},#{data.deviceName},#{data.deviceParentName},#{data.ip}) values(",
            "#{data.createTime},#{data.intValue},#{data.booleanValue},#{data.floatValue},#{data.status}) ",
            "</foreach>",
            "</script>"
    })
    int insertDeviceList(@Param("deviceList")List<DeviceModel> deviceList,@Param("superTable") String superTable);


}

六、写service

java 复制代码
/**
 * 数据处理service
 */
@Service
@Slf4j
public class DeviceService {

	 //TDengine中的superTable的名字
    private static final String superTable = "super_table";
    
    public void saveToTDengineNew(List<DeviceModel> deviceList){
        this.deviceMapper.insertDeviceList(deviceList,superTable);
    }
    public DeviceModel getDeviceMsgByTDengine(String deviceId) throws Exception {
    	return deviceMapper.getDeviceNewMsgByDeviceId(deviceId);
    }

}

七、处理controller即可。完成。

下班啦,原生方式改天写

相关推荐
说淑人2 小时前
Spring Cloud & 以Gateway实现限流(自定义返回内容)
java·spring cloud·gateway·限流
佛祖让我来巡山2 小时前
【Java持久层技术演进全解析】从JDBC到MyBatis再到MyBatis-Plus
mybatis·jdbc·mybatisplus·持久层框架
冼紫菜10 小时前
【Spring Boot 多模块项目】@MapperScan失效、MapperScannerConfigurer 报错终极解决方案
java·开发语言·mybatis
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧13 小时前
MyBatis快速入门——实操
java·spring boot·spring·intellij-idea·mybatis·intellij idea
菲兹园长20 小时前
MyBatis-Plus
java·开发语言·mybatis
计算机学姐20 小时前
基于SpringBoot的在线教育管理系统
java·vue.js·spring boot·后端·mysql·spring·mybatis
nangonghen1 天前
spring cloud loadbalancer实现机房感知的负载均衡
spring·spring cloud·负载均衡
weixin_437398212 天前
RabbitMQ深入学习
java·分布式·后端·spring·spring cloud·微服务·rabbitmq
残花月伴2 天前
springCloud/Alibaba常用中间件之Nacos服务注册与发现
spring·spring cloud·中间件
Kx…………2 天前
Java EE(Spring+Spring MVC+MyBatis)从入门到精通企业级应用开发教程——1初识MyBatis框架
学习·spring·java-ee·mvc·mybatis