欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中String的JdbcTemplate連接SQLServer數(shù)據(jù)庫的方法

 更新時間:2021年10月27日 11:07:11   作者:勝金  
這篇文章主要介紹了Java中String的JdbcTemplate連接SQLServer數(shù)據(jù)庫的方法,在研發(fā)過程中我們需要與其他系統(tǒng)對接的場景,連接SQLServer拉取數(shù)據(jù),所以就用jdbc連接數(shù)據(jù)庫的方式連接外部數(shù)據(jù)源,需要的朋友可以參考下

  很久沒寫文章了,一方面是最近幾個月比較忙,沒太多時間,另一方面是最近拖延癥嚴重,寫文章的想法總是一拖再拖。今天找一個小案例寫一下,與懶惰對抗一下。

  首先說一下背景,我們在項目中做數(shù)據(jù)持久化一般都是用mybatis或者hibernate開發(fā)框架,進行數(shù)據(jù)庫連接和操作,最近做GIS仿真產(chǎn)品研發(fā),根據(jù)需求需要保存三部分數(shù)據(jù):1、業(yè)務(wù)數(shù)據(jù),數(shù)據(jù)量比較小;2、GIS數(shù)據(jù),需要用到空間關(guān)系;3、物聯(lián)數(shù)據(jù),數(shù)據(jù)量大,在我們開發(fā)自測階段數(shù)據(jù)量就可以達到每天百萬以上。根據(jù)以上數(shù)據(jù)特點,我們使用了傳統(tǒng)的MySQL數(shù)據(jù)庫、空間數(shù)據(jù)庫PostgreSQL、TD engine時序數(shù)據(jù)庫,項目中做了spring boot多數(shù)據(jù)源動態(tài)切換。今天的重點不是多數(shù)據(jù)源的實現(xiàn),這個應(yīng)用以后會在另外一篇文章中介紹;在研發(fā)過程中我們需要與其他系統(tǒng)對接的場景,連接SQLServer拉取數(shù)據(jù),項目本身已經(jīng)做了多數(shù)據(jù)源,如果繼續(xù)添加數(shù)據(jù)源就加大了系統(tǒng)的難度,所以就用jdbc連接數(shù)據(jù)庫的方式連接外部數(shù)據(jù)源,下面看代碼。

一、引入依賴jar包

  項目用的是Spring Boot,創(chuàng)建好項目以后,引入下面依賴:

<dependencies>
        
        <dependency>
            <groupId>com.microsoft.sqlserver</groupId>
            <artifactId>mssql-jdbc</artifactId>
            <scope>runtime</scope>
        </dependency>

    </dependencies>

二、Utils開發(fā)

  1、創(chuàng)建實體類,實現(xiàn)org.springframework.jdbc.core.RowMappe接口的mapRow(ResultSet rs, int rowNum)方法。

package com.johan.handler.task.iotSync.bean;
import lombok.Data;
import org.apache.commons.lang3.StringUtils;
import org.springframework.jdbc.core.RowMapper;

import java.sql.ResultSet;
import java.sql.SQLException;

/**
 * @author: Johan
 * @date: 2021/10/18
 * @desc: IOT信息
 */
@Data
public class IotDG implements RowMapper {
    /**
     * 標簽名稱
     */
    private String tagName;

    /**
     * 標簽描述
     */
    private String tagDesc;

    /**
     * 標簽值
     */
    private Double tagVal;

    /**
     * 標簽單位
     */
    private String tagUnit;

    /**
     * 類型,0 壓力,1 流量
     */
    private String type;


    @Override
    public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
        IotDG iotDG = new IotDG();
        iotDG.setTagName(rs.getString("TagName"));
        iotDG.setTagDesc(rs.getString("TagDesc"));
        iotDG.setTagVal(rs.getDouble("Value"));
        iotDG.setTagUnit(rs.getString("TagUnit"));
        iotDG.setType(rs.getString("Type"));

        return iotDG;
    }
}

  2、連接數(shù)據(jù)庫,讀取表數(shù)據(jù)

package com.johan.handler.task.iotSync.iotConvert;

import com.johan.handler.task.iotSync.bean.IotDG;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DriverManagerDataSource;

import java.sql.*;
import java.util.List;

/**
 * @author johan
 * @Description SQL server
 * @time 2021/10/18 18:26
 */
public class JDBCUtils {

    private static JdbcTemplate jdbcTemplate;
    static {
        String driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
        String url ="jdbc:sqlserver://10.25.23.172:1433;databaseName=SCADA_Data_3040";//連接地址
        String user ="SLSL";//用戶
        String password ="Admin@3040";//密碼

        DriverManagerDataSource dataSource=new DriverManagerDataSource();
        dataSource.setUrl(url);
        dataSource.setDriverClassName(driver);
        dataSource.setUsername(user);
        dataSource.setPassword(password);

        jdbcTemplate=new JdbcTemplate(dataSource);
    }


    public static List<IotDG> listAll(int type){
        String sql = "SELECT * FROM RealData where Type=" + type;

//        System.out.println(iotDGList);
        return jdbcTemplate.query(sql,new IotDG());
    }


}

  3、測試

  方法是靜態(tài)的,直接調(diào)用即可。

package com.johan.domain.iot;

import com.johan.handler.task.iotSync.bean.IotDG;
import com.johan.handler.task.iotSync.iotConvert.JDBCUtils;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;

/**
 * @author johan
 * @time 2021/10/22 17:57
 */
@SpringBootTest
@Slf4j
public class IotDomainTest {

    @Test
    public void jdbcTest(){
        List<IotDG> iotDGList = JDBCUtils.listAll(0);
        System.out.println(iotDGList);
    }

}

  不只是SQLServer,我們常用的MySQL、Oracle等都可以用JdbcTemplate連接。

到此這篇關(guān)于Java中String的JdbcTemplate連接SQLServer數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)java中JdbcTemplate連接SQLServer數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java 8 中的 10 個特性總結(jié)及詳解

    Java 8 中的 10 個特性總結(jié)及詳解

    本主要介紹Java 8中的新特性,這里整理了相關(guān)資料并整理了10個特性,逐一介紹說明,有興趣的朋友可以參考下
    2016-09-09
  • Spring中MVC模塊代碼詳解

    Spring中MVC模塊代碼詳解

    這篇文章主要介紹了Spring中MVC模塊代碼詳解,涉及Controller的簡單介紹,具有一定借鑒價值,需要的朋友可以參考下。
    2017-11-11
  • 基于springboot服務(wù)間Feign調(diào)用超時的解決方案

    基于springboot服務(wù)間Feign調(diào)用超時的解決方案

    這篇文章主要介紹了基于springboot服務(wù)間Feign調(diào)用超時的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • java三個環(huán)境變量配置簡單教程

    java三個環(huán)境變量配置簡單教程

    這篇文章主要為大家詳細介紹了java三個環(huán)境變量配置簡單教程,配置path變量、配置classpath變量、最后是配置JAVA_HOME變量,感興趣的小伙伴們可以參考一下
    2016-07-07
  • Java?C++分別實現(xiàn)滑動窗口的最大值

    Java?C++分別實現(xiàn)滑動窗口的最大值

    這篇文章主要介紹了分別通過Java和C++實現(xiàn)滑動窗口最大值,即給定一個數(shù)組?nums?和滑動窗口的大小?k,請找出所有滑動窗口里的最大值。感興趣的可以了解一下
    2021-12-12
  • Springboot整合thymleaf模板引擎過程解析

    Springboot整合thymleaf模板引擎過程解析

    這篇文章主要介紹了Springboot整合thymleaf模板引擎過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • Java協(xié)程編程之Loom

    Java協(xié)程編程之Loom

    這篇文章主要介紹了Java協(xié)程編程Loom的方法,需要的朋友請看下文
    2021-08-08
  • Eclipse中常用快捷鍵匯總

    Eclipse中常用快捷鍵匯總

    這篇文章主要介紹了Eclipse中常用快捷鍵,文中介紹的非常詳細,幫助大家更好的利用eclipse開發(fā),感興趣的朋友可以了解下
    2020-07-07
  • 深入理解java虛擬機的故障處理工具

    深入理解java虛擬機的故障處理工具

    大家都知道在給系統(tǒng)定位問題的時候,知識、經(jīng)驗是關(guān)鍵基礎(chǔ),數(shù)據(jù)是依據(jù),工具是運用知識處理數(shù)據(jù)的手段。Java開發(fā)人員可以在jdk安裝的bin目錄下找到除了java,javac以外的其他命令。這些命令主要是一些用于監(jiān)視虛擬機和故障處理的工具,下面來看看詳細的介紹。
    2016-11-11
  • Java開發(fā)崗位面試被問到反射怎么辦

    Java開發(fā)崗位面試被問到反射怎么辦

    這篇文章主要介紹了java 面向?qū)ο竺嬖嚰\的相關(guān)資料,這里整理了面向?qū)ο蟮幕A(chǔ)知識,幫助大家學(xué)習(xí)理解此部分的知識,需要的朋友可以參考下
    2021-07-07

最新評論