基於SpringBoot實現操作GaussDB(DWS)的項目實戰

来源:https://www.cnblogs.com/huaweiyun/archive/2023/02/23/17147208.html
-Advertisement-
Play Games

摘要:本文就使用springboot結合mybatis plus在項目中實現對GaussDB(DWS)的增刪改查操作。 本文分享自華為雲社區《基於SpringBoot實現操作GaussDB(DWS)的項目實戰【玩轉PB級數倉GaussDB(DWS)】》,作者:清雨小竹。 GaussDB(DWS) 數 ...


摘要:本文就使用springboot結合mybatis plus在項目中實現對GaussDB(DWS)的增刪改查操作。

本文分享自華為雲社區《基於SpringBoot實現操作GaussDB(DWS)的項目實戰【玩轉PB級數倉GaussDB(DWS)】》,作者:清雨小竹。

GaussDB(DWS)

數據倉庫服務GaussDB(DWS) 是一種基於華為雲基礎架構和平臺的線上數據處理資料庫,提供即開即用、可擴展且完全托管的分析型資料庫服務。GaussDB(DWS)是基於華為融合數據倉庫GaussDB產品的雲原生服務 ,相容標準ANSI SQL 99和SQL 2003,同時相容PostgreSQL/Oracle資料庫生態,為各行業PB級海量大數據分析提供有競爭力的解決方案。

GaussDB(DWS) 基於Shared-nothing分散式架構,具備MPP (Massively Parallel Processing)大規模並行處理引擎,由眾多擁有獨立且互不共用的CPU、記憶體、存儲等系統資源的邏輯節點組成。在這樣的系統架構中,業務數據被分散存儲在多個節點上,數據分析任務被推送到數據所在位置就近執行,並行地完成大規模的數據處理工作,實現對數據處理的快速響應。

zh-cn_image_0000001231270999.png

Spring Boot

Spring Boot是一個構建在Spring框架頂部的項目。它提供了一種簡便,快捷的方式來設置,配置和運行基於Web的簡單應用程式。它是一個Spring模塊,提供了 RAD(快速應用程式開發)功能。它用於創建獨立的基於Spring的應用程式,因為它需要最少的Spring配置,因此可以運行。簡而言之,Spring Boot是 Spring Framework 和 嵌入式伺服器的組合。在Spring Boot不需要XML配置(部署描述符)。它使用約定優於配置軟體設計範例,這意味著可以減少開發人員的工作量。我們可以使用Spring STS IDE 或 Spring Initializr 進行開發Spring Boot Java應用程式。

什麼是Spring Boot

Mybatis plus(MP)

MyBatis 是一款優秀的持久層框架,它支持定製化 SQL、存儲過程以及高級映射。MyBatis 避免了幾乎所有的 JDBC 代碼和手動設置參數以及獲取結果集,MyBatis 可以使用簡單的 XML 或註解來配置和映射原生信息,將介面和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java對象)映射成資料庫中的記錄。MyBatis-Plus(簡稱 MP)是一個 MyBatis 的增強工具,在 MyBatis 的基礎上只做增強不做改變,為簡化開發、提高效率而生。

華為雲官方文檔給出了使用JDBC連接GaussDB(DWS)並實現增刪改查基本操作的教程和代碼示例。https://support.huaweicloud.com/devg-dws/dws_04_0085.html,在java開發中springboot作為一個常用的開發框架在很多項目中使用,下麵就使用springboot結合mybatis plus在項目中實現對GaussDB(DWS)的增刪改查操作。

一、新建springboot項目

1.打開idea基於嚮導新建springboot項目。

1.png

2.添加依賴JDBC API和SpringWeb

22.png

3.項目新建完成後打開新建libs文件夾,把jdbc驅動複製到libs目錄下。https://support.huaweicloud.com/mgtg-dws/dws_01_0032.html

  • gsjdbc4.jar:與PostgreSQL保持相容,其中類名、類結構與PostgreSQL驅動完全一致,曾經運行於PostgreSQL的應用程式可以直接移植到當前系統中使用。
  • gsjdbc200.jar:如果同一JVM進程內需要同時訪問PostgreSQL及GaussDB(DWS) 請使用該驅動包。該包主類名為“com.huawei.gauss200.jdbc.Driver”(即將“org.postgresql”替換為“com.huawei.gauss200.jdbc”) ,資料庫連接的URL首碼為“jdbc:gaussdb”,其餘與gsjdbc4.jar相同。、

    23.png

4.jar包上滑鼠點擊右鍵,點擊Add as Library。

5.png

5.打開build.gradle,添加mybatis plus依賴,由於GaussDB DWS相容PostgreSQL所以runtimeOnly可以使用org.postgresql:postgresql

dependencies {
    //mybatis-plus
    implementation 'com.baomidou:mybatis-plus-boot-starter:3.5.2'

    implementation 'org.springframework.boot:spring-boot-starter-jdbc'
    implementation 'org.springframework.boot:spring-boot-starter-web'
    runtimeOnly 'org.postgresql:postgresql'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
}

6.打開application.properties配置資料庫源信息。

spring.datasource.driver-class-name=org.postgresql.Driver
spring.datasource.url=jdbc:postgresql://xx.xx.xx.xx:8000/database?currentSchema=traffic_data
spring.datasource.username=dbadmin
spring.datasource.password=xxxxxx

二、配置mybatis plus

7.新增數據表

CREATE TABLE "traffic_data"."customer" (
"id" int4,
"c_customer_sk" int4,
"c_customer_name" varchar(32)
);

8.新增包名com.zz.testdws.mapper和com.zz.testdws.entity

24.png

9.新建實體類對象customer.java和Mappder對象CustomerMapper.java文件

package com.zz.testdws.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;

/**
 * <p>
 * 
 * </p>
 *
 * @author zzzili
 * @since 2023-02-16
 */
public class customer  {

    private static final long serialVersionUID = 1L;

    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    private Integer cCustomerSk;

    private String cCustomerName;

    @Override
    public String toString() {
        return "customer{" +
                "id=" + id +
                ", cCustomerSk=" + cCustomerSk +
                ", cCustomerName='" + cCustomerName + '\'' +
                '}';
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Integer getcCustomerSk() {
        return cCustomerSk;
    }

    public void setcCustomerSk(Integer cCustomerSk) {
        this.cCustomerSk = cCustomerSk;
    }

    public String getcCustomerName() {
        return cCustomerName;
    }

    public void setcCustomerName(String cCustomerName) {
        this.cCustomerName = cCustomerName;
    }
}
package com.zz.testdws.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zz.testdws.entity.customer;

/**
 * <p>
 *  Mapper 介面
 * </p>
 *
 * @author zzzili
 * @since 2023-02-15
 */
public interface CustomerMapper extends BaseMapper<customer> {
}

10.打開TestDwsSpringBootApplication.java文件,添加mapper掃描器註解@MapperScan("com.zz.testdws.mapper")

package com.zz.testdws;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@MapperScan("com.zz.testdws.mapper")
public class TestDwsSpringBootApplication {
    public static void main(String[] args) {
        SpringApplication.run(TestDwsSpringBootApplication.class, args);
    }
}

三、測試數據

11.打開TestDwsSpringBootApplicationTests.java文件編寫代碼,測試用sql執行增刪改查數據。

 @Autowired
    DataSource dataSource;

    @Test
    void testDoSQL() throws SQLException {
        System.out.println(dataSource.getClass());

        //獲取連接
        Connection con =  dataSource.getConnection();
        //調用Connection的createStatement方法創建語句對象
        Statement stmt = con.createStatement();
        //調用Statement的executeUpdate方法執行SQL語句
        //int rc = stmt.executeUpdate("CREATE TABLE customer_t1(c_customer_sk INTEGER, c_customer_name VARCHAR(32));");
        //System.out.println("rc = " + rc);

        //int rc = stmt.executeUpdate("INSERT INTO customer_t1(c_customer_sk,c_customer_name) values('1001','zhangsan');");
        //System.out.println("insert rc = " + rc);

        //查詢數據
        ResultSet rs= stmt.executeQuery("select * from customer_t1");
        //遍曆數據
        while(rs.next()){
            String sk = rs.getString("c_customer_sk");
            String name = rs.getString("c_customer_name");
            System.out.println("sk:"+sk+" 姓名:"+name);
        }

        con.close();
    }

28.png

12.編寫代碼測試使用mybatis plus實現增刪改查。

    @Autowired
    CustomerMapper customerMapper;

    @Test
    void testMybatis(){
        //增加
        customer cus=new customer();
        cus.setcCustomerName("zzzili");
        cus.setcCustomerSk(123456);
        cus.setId(8);
        customerMapper.insert(cus);
        //
        cus.setcCustomerSk(66666);
        customerMapper.updateById(cus);

        //
        List<customer> list = customerMapper.selectList(null);
        System.out.println("list size="+list.size());
        for(customer node :list){
            System.out.println(node);
        }

        //刪除
        customerMapper.deleteById(1);

    }

26.png

27.png


總結:通過以上實驗實現了在springboot框架中利用mybatis ORM框架對GaussDB(DWS)的增刪改查(ARUD)操作,在項目開發中更具有實用性。本示例項目已上傳至附件。

附件:測試項目代碼.rar9.50MB

 

點擊關註,第一時間瞭解華為雲新鮮技術~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.說說你知道的ORM框架? 2.請問對EFCore有瞭解嗎? 3.說說EFCore查詢的性能調優小技巧? 4.EFCore 如果通過數據生成實體和DbContext? 5.說說對SaveChanges的理解? 6.說說對EFCore中EntityState的理解。? 7.說說什麼是導航屬性和引用屬 ...
  • 概述 面臨一個複雜對象的創建工作,通常由各個部分的子對象用一定的演算法構成。子部件(對象)比較多,對象不能當作一個完整的對象或者產品使用(郵件:發件人,收件人、抄送人、主題、郵件內容)子部件需要按照一定的順序賦值才有一定的意義,在某個子部件沒有賦值之前,另一個子部件就無法賦值。 類圖 註:該類圖來源網 ...
  • Excel 公式引用當前單元格左側單元格 引用當前單元格左側的第一個單元格:=OFFSET(INDIRECT(ADDRESS(ROW(), COLUMN())),0,-1)。 ROW()返回當前單元格的行號,COLUMN()返回當前單元格的列號。 ADDRESS函數可以根據指定行號和列號獲得工作表中 ...
  • # MySQL調優 ## 資料庫優化常見方案 1. 優化shema,sql語句+索引2. 加緩存,memcached,redis3. 主從複製,讀寫分離4. 垂直拆分5. 水平拆分 為了知道怎麼優化SQL,必須先清楚SQL的生命周期 ## SQL生命周期 1. 應用伺服器連接資料庫伺服器,建立一個T ...
  • 閱識風雲是華為雲信息大咖,擅長將複雜信息多元化呈現,其出品的一張圖(雲圖說)、深入淺出的博文(雲小課)或短視頻(雲視廳)總有一款能讓您快速上手華為雲。更多精彩內容請單擊此處。 摘要:Spark Streaming是一種構建在Spark上的實時計算框架,擴展了Spark處理大規模流式數據的能力。本文介 ...
  • SQL中的排序 使用關鍵字:ORDER BY ORDER BY 欄位名後使用ASC升序表示;使用DESC表示降序。 ORDER BY 後面可以使用列的別名進行排序(列的別名只能在ORDER BY中使用,不能再HWERE後使用) WHERE需要再FROM後,ORDER BY前聲明!! 多級排序,ORD ...
  • 1.1 技術發展 redis是用來解決性能問題的資料庫 技術的分類: 解決功能性問題:Java、Jsp、RDBMS、Tomcat、HTML、Linux、JDBC、SVN 解決擴展性問題:Struts、Spring、SpringMVC、Hibernate、Mybatis 解決性能問題:NoSQL、Ja ...
  • 研發背景 公司安全部目前針對內部系統的網路訪問日誌的安全審計,大部分都是T+1時效,每日當天,啟動Python編寫的定時任務,完成昨日的日誌審計和檢測,定時任務運行完成後,統一進行企業微信告警推送。這種方案在目前的網路環境和人員規模下,呈現兩個痛點,一是面對日益頻繁的網路攻擊、釣魚鏈接,T+1的定時 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...