一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java中String的JdbcTemplate連接SQLServer數(shù)據庫的方法

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

2022-03-02 01:04勝金 Java教程

這篇文章主要介紹了Java中String的JdbcTemplate連接SQLServer數(shù)據庫的方法,在研發(fā)過程中我們需要與其他系統(tǒng)對接的場景,連接SQLServer拉取數(shù)據,所以就用jdbc連接數(shù)據庫的方式連接外部數(shù)據源,需要的朋友可以參考下

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

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

一、引入依賴jar包

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

?
1
2
3
4
5
6
7
8
9
<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)方法。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
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ù)據庫,讀取表數(shù)據

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
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)的,直接調用即可。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
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連接。

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

原文鏈接:https://www.cnblogs.com/JohanChan/p/15469453.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品成人扳一级aa毛片 | 国产精品露脸国语对白手机视频 | 和老外3p爽粗大免费视频 | 99ri国产在线 | 魔镜号中文字幕 | 麻豆天美精东果冻传媒在线 | 青柠影视在线播放观看高清 | 国产区成人综合色在线 | 日本精a在线观看 | japanesexxxx日本妞 | 奇米影视亚洲狠狠色 | 大肚孕妇的高h辣文 | 四虎影视在线影院在线观看 | 天天亚洲综合 | 五月最新商场女厕所高跟嘘嘘 | 日本大学生xxxxx69泡妞 | 欧美国产合集在线视频 | 98精品全国免费观看视频 | 欧美人在线一区二区三区 | 国产精品免费拍拍拍 | 成人au免费视频影院 | 丝瓜视频在线观看污 | 精品一区二区三区波多野结衣 | 草草视频免费在线观看 | 精品欧美一区二区三区在线观看 | 亚洲 欧美 日韩 国产 视频 | 99人中文字幕亚洲区 | 精品一区二区国语对白 | 精品亚洲午夜久久久久 | 天天草人人草 | 91精品国产91热久久久久福利 | 亚洲精品国产综合久久一线 | 精品性影院一区二区三区内射 | 久久人妻少妇嫩草AV無碼 | 憋尿调教绝望之岛 | 国士李风起全文在线阅读 | 艹的好爽| 午夜一级视频 | 日本国产高清色www视频在线 | 1769亚洲欧美资源站 | 四虎永久免费地址ww417 |