【SpringBoot】 整合MyBatis+Postgresql

?MyBatis 是一個輕量級的持久化框架,用于簡化數據庫訪問和操作。它通過將 SQL 語句與 Java 代碼分離,允許開發者使用 XML 或注解來配置 SQL 語句,并將結果映射為 Java 對象。MyBatis 提供了靈活的 SQL 控制,適合需要精細控制 SQL 的場景,同時支持動態 SQL、存儲過程和緩存等功能,以滿足不同的需求?。

?整合MyBatis

數據庫安裝:

【PostgreSQL】安裝及使用(Navicat/Arcgis),連接(C#)_postgresql navicat-CSDN博客

數據庫連接

下載驅動

由于我電腦上安裝的兩個版本的Postgresql12和14所以端口得修改

添加表數據

打開編寫窗口

以下是mysql數據庫的語句

create database if not exists mybatis;use mybatis;create table user(id int unsigned primary key auto_increment comment 'ID',name varchar(100) comment '姓名',age tinyint unsigned comment '年齡',gender tinyint unsigned comment '性別, 1:男, 2:女',phone varchar(11) comment '手機號'
) comment '用戶表';insert into user(id, name, age, gender, phone) VALUES (null,'白眉鷹王',55,'1','18800000000');
insert into user(id, name, age, gender, phone) VALUES (null,'金毛獅王',45,'1','18800000001');
insert into user(id, name, age, gender, phone) VALUES (null,'青翼蝠王',38,'1','18800000002');
insert into user(id, name, age, gender, phone) VALUES (null,'紫衫龍王',42,'2','18800000003');
insert into user(id, name, age, gender, phone) VALUES (null,'光明左使',37,'1','18800000004');
insert into user(id, name, age, gender, phone) VALUES (null,'光明右使',48,'1','18800000005');

以下是postgresql的語句(注意不要建立user表)

-- 1. 創建數據庫(兼容IF NOT EXISTS語法需調整)
CREATE DATABASE mybatis;-- 2. 連接數據庫(PostgreSQL無USE命令)
\c mybatis;-- 3. 創建表(處理自增主鍵、無符號類型、注釋語法)
CREATE TABLE "usertest" (id SERIAL PRIMARY KEY,  -- 自增主鍵改造name VARCHAR(100),      -- 字符串類型兼容age SMALLINT,           -- TINYINT UNSIGNED → SMALLINTgender SMALLINT,        -- 同age處理邏輯phone VARCHAR(11)       -- 保留原定義
);
COMMENT ON TABLE "usertest" IS '用戶表';  -- 表注釋單獨設置
COMMENT ON COLUMN "usertest".id IS 'ID';
COMMENT ON COLUMN "usertest".name IS '姓名';
COMMENT ON COLUMN "usertest".age IS '年齡';
COMMENT ON COLUMN "usertest".gender IS '性別, 1:男, 2:女';
COMMENT ON COLUMN "usertest".phone IS '手機號';-- 4. 插入數據(處理自增列、單引號規范)
INSERT INTO "usertest" (name, age, gender, phone) VALUES('白眉鷹王', 55, 1, '18800000000'),  -- 省略自增id [[20]][[10]]('金毛獅王', 45, 1, '18800000001'),('青翼蝠王', 38, 1, '18800000002'),('紫衫龍王', 42, 2, '18800000003'),('光明左使', 37, 1, '18800000004'),('光明右使', 48, 1, '18800000005');

添加鏡像

    <!-- 配置阿里云倉庫 --><repositories><repository><id>aliyun-repos</id><url>https://maven.aliyun.com/repository/public</url><releases><enabled>true</enabled></releases><snapshots><enabled>false</enabled></snapshots></repository></repositories><pluginRepositories><pluginRepository><id>aliyun-repos</id><url>https://maven.aliyun.com/repository/public</url><releases><enabled>true</enabled></releases><snapshots><enabled>false</enabled></snapshots></pluginRepository></pluginRepositories>

添加mybatis起步依賴

在新工程上操作

        <!--mybatis的起步依賴--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>3.0.3</version></dependency>

添加數據庫的驅動依賴

        <!--postgresql驅動依賴--><dependency><groupId>org.postgresql</groupId><artifactId>postgresql</artifactId></dependency>

添加數據庫配置

spring:application:name: springboot-mybatisdatasource:driver-class-name: org.postgresql.Driverurl: jdbc:postgresql://localhost:5432/mybatisusername: postgrespassword: postgres

創建User實體類

package com.zwh.springbootmybatis.pojo;public class User {private Integer id;private String name;private Short age;private Short gender;private String phone;public User() {}public User(Integer id, String name, Short age, Short gender, String phone) {this.id = id;this.name = name;this.age = age;this.gender = gender;this.phone = phone;}public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Short getAge() {return age;}public void setAge(Short age) {this.age = age;}public Short getGender() {return gender;}public void setGender(Short gender) {this.gender = gender;}public String getPhone() {return phone;}public void setPhone(String phone) {this.phone = phone;}@Overridepublic String toString() {return "User{" +"id=" + id +", name='" + name + '\'' +", age=" + age +", gender=" + gender +", phone='" + phone + '\'' +'}';}
}

創建數據庫交互接口

package com.zwh.springbootmybatis.mapper;import com.zwh.springbootmybatis.pojo.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;@Mapper
public interface UserMapper {@Select("select * from user where id = #{id}")public User findById(Integer id);
}

創建業務邏輯接口?

package com.zwh.springbootmybatis.service;import com.zwh.springbootmybatis.pojo.User;public interface UserService {public User findById(Integer id);
}

創建接口的實現類?

package com.zwh.springbootmybatis.service.impl;import com.zwh.springbootmybatis.mapper.UserMapper;
import com.zwh.springbootmybatis.pojo.User;
import com.zwh.springbootmybatis.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class UserServiceImpl implements UserService {@Autowiredprivate UserMapper userMapper;@Overridepublic User findById(Integer id) {return userMapper.findById(id);}
}

處理前端請求?

package com.zwh.springbootmybatis.Controller;import com.zwh.springbootmybatis.pojo.User;
import com.zwh.springbootmybatis.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class UserController {@Autowiredprivate UserService userService;@RequestMapping("/findById")public User findById(Integer id){return userService.findById(id);}
}

運行?

http://127.0.0.1:8080/findById?id=1

?

mapperserviceimplpojocontroller講解

在Spring Boot中,mapperserviceimplpojocontroller是分層架構中的關鍵組件,它們分別負責不同的職責:

  1. Mapper:通常指MyBatis的Mapper接口,用于定義與數據庫交互的方法。這些方法的具體實現(如SQL語句)通常放在mapper.xml文件中。Mapper接口通過@Mapper注解標識,并且可以繼承BaseMapper等通用接口。

  2. Service:表示業務邏輯層接口,定義了業務邏輯的方法。Service接口通常由ServiceImpl實現,實現類中會調用Mapper接口來執行數據庫操作。

  3. ServiceImpl:是Service接口的實現類,負責具體的業務邏輯處理。它通常通過@Service注解標識,并且會注入Mapper接口以獲取數據庫操作能力。

  4. Pojo(Plain Old Java Object)?:表示實體類,通常用于映射數據庫表。Pojo類包含字段和對應的getter/setter方法,用于在Java對象與數據庫之間進行數據轉換。

  5. Controller:負責處理前端請求,作為應用的入口點。Controller通過@Controller@RestController注解標識,并調用Service層的方法來處理業務邏輯。

這些組件共同構成了Spring Boot的分層架構,使得代碼結構清晰、易于維護和擴展。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/90910.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/90910.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/90910.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

無縫銜接直播流體驗

文章目錄前言&#x1f9e0; 1. 為什么能“無縫銜接”&#xff1f;&#x1f9f0; 2. Flutter 實現方案? 總體策略&#x1f3af; 核心技術點? a. 使用全局播放器管理器&#xff08;單例模式&#xff09;? b. 廣場頁中的直播卡片使用播放器? c. 詳情頁復用控制器? d. 頁面切換…

[論文閱讀] 軟件工程 | 首個德語軟件工程情感分析黃金標準數據集:構建與價值解析

首個德語軟件工程情感分析黃金標準數據集&#xff1a;構建與價值解析 論文標題&#xff1a;A German Gold-Standard Dataset for Sentiment Analysis in Software EngineeringarXiv:2507.07325 A German Gold-Standard Dataset for Sentiment Analysis in Software Engineering…

PyTorch編程實踐:一文就入門的上手開發!

引言 PyTorch作為當今深度學習領域最流行的框架之一&#xff0c;以其動態計算圖、直觀的Python接口和強大的GPU加速能力&#xff0c;贏得了眾多研究人員和工程師的青睞。本文將深入探討PyTorch的編程實踐&#xff0c;從基礎概念到高級應用&#xff0c;幫助讀者全面掌握這一強大…

關于學習docker中遇到的問題

Cannot connect to the Docker daemon at unix:///home/pc/.docker/desktop/docker.sock. Is the docker daemon running?如何配置新的路徑 #運行這條命令&#xff0c;查看docker狀態 sudo systemctl status docker如圖所示表示監聽路徑不對&#xff0c;因此修改路徑即可&…

無法打開windows安全中心解決方案

系統還原或重置&#xff1a;如果以上方法均無效&#xff0c;可嘗試系統還原&#xff0c;使用之前創建的還原點恢復系統。或在設置中選擇 “系統> 恢復 > 重置此電腦”&#xff0c;選擇 “保留我的文件” 以避免數據丟失。創建新用戶賬戶&#xff1a;按下 Win I 打開設置…

復習筆記 33

緒論 《幻術》 張葉蕾 我該怎么承認&#xff0c; 一切都是幻境。 函數的基本性質和無窮小量及其階的比較 我感覺強化課我要跟上的話&#xff0c;我需要把基礎&#xff0c;強化的講義&#xff0c;還有練習冊上面的所有題都刷爛。不然我感覺自己考 140 完全就是癡人說夢。搞笑呢。…

算法學習筆記:12.快速排序 ——從原理到實戰,涵蓋 LeetCode 與考研 408 例題

快速排序是計算機科學中最經典的排序算法之一&#xff0c;由 Tony Hoare 在 1960 年提出。它憑借平均時間復雜度 O (nlogn)、原地排序&#xff08;空間復雜度 O (logn)&#xff0c;主要來自遞歸棧&#xff09;以及良好的實際性能&#xff0c;成為工業界處理大規模數據排序的首選…

unity 有打擊感的圖片,怎么做動畫,可以表現出良好的打擊效果

完整實現腳本:using UnityEngine; using UnityEngine.UI; using System.Collections;[RequireComponent(typeof(Image))] public class HitEffectController : MonoBehaviour {[Header("基礎設置")]public float hitDuration 0.5f; // 打擊效果總時長[Header("…

cuda編程筆記(7)--多GPU上的CUDA

零拷貝內存 在流中&#xff0c;我們介紹了cudaHostAlloc這個函數&#xff0c;它有一些標志&#xff0c;其中cudaHostAllocMapped允許內存映射到設備&#xff0c;也即GPU可以直接訪問主機上的內存&#xff0c;不用額外再給設備指針分配內存 通過下面的操作&#xff0c;即可讓設…

IP地址混亂?監控易IPAM實現全網地址自動化管理與非法接入告警

IP地址出現混亂狀況&#xff1f;監控易IPAM能夠達成對全網地址予以自動化管理的目標&#xff0c;同時還可針對非法接入的情況發出告警信息。辦公室毫無預兆地突然斷網了&#xff0c;經過一番仔細排查之后&#xff0c;發現原來是IP地址出現了沖突的情況。有人私自接了路由器&…

安全監測預警平臺的應用場景

隨著城市化進程加快和基礎設施規模擴大&#xff0c;各類安全風險日益突出。安全監測預警平臺作為現代安全管理的重要工具&#xff0c;通過整合物聯網、大數據、人工智能等先進技術&#xff0c;實現對各類安全隱患的實時監測、智能分析和精準預警。本文將詳細探討安全監測預警平…

007_用例與應用場景

用例與應用場景 目錄 內容創作編程開發數據分析客戶服務教育培訓商業智能研究輔助 內容創作 文案撰寫 應用場景&#xff1a; 營銷文案和廣告語產品描述和說明書社交媒體內容郵件營銷內容 實際案例&#xff1a; 任務&#xff1a;為新款智能手表撰寫產品描述 輸入&#x…

Unity物理系統由淺入深第一節:Unity 物理系統基礎與應用

Unity物理系統由淺入深第一節&#xff1a;Unity 物理系統基礎與應用 Unity物理系統由淺入深第二節&#xff1a;物理系統高級特性與優化 Unity物理系統由淺入深第三節&#xff1a;物理引擎底層原理剖析 Unity物理系統由淺入深第四節&#xff1a;物理約束求解與穩定性 Unity 引擎…

《[系統底層攻堅] 張冬〈大話存儲終極版〉精讀計劃啟動——存儲架構原理深度拆解之旅》-系統性學習筆記(適合小白與IT工作人員)

&#x1f525; 致所有存儲技術探索者筆者近期將系統攻克存儲領域經典巨作——張冬老師編著的《大話存儲終極版》。這部近千頁的存儲系統圣經&#xff0c;以庖丁解牛的方式剖析了&#xff1a;存儲硬件底層架構、分布式存儲核心算法、超融合系統設計哲學等等。喜歡研究數據存儲或…

flutter鴻蒙版 環境配置

flutter支持開發鴻蒙,但是需要專門的flutter鴻蒙項目, Flutter鴻蒙化環境配置&#xff08;windows&#xff09;_flutter config --ohos-sdk-CSDN博客

Java 高級特性實戰:反射與動態代理在 spring 中的核心應用

在 Java 開發中&#xff0c;反射和動態代理常被視為 “高級特性”&#xff0c;它們看似抽象&#xff0c;卻支撐著 Spring、MyBatis 等主流框架的核心功能。本文結合手寫 spring 框架的實踐&#xff0c;從 “原理” 到 “落地”&#xff0c;詳解這兩個特性如何解決實際問題&…

Codeforces Round 855 (Div. 3)

A. Is It a Cat? 去重&#xff0c; 把所有字符看成大寫字符&#xff0c; 然后去重&#xff0c; 觀察最后結果是不是“MEOW” #include <bits/stdc.h> #define int long longvoid solve() {int n;std::cin >> n;std::string ans, t;std::cin >> ans;for (int…

Scrapy選擇器深度指南:CSS與XPath實戰技巧

引言&#xff1a;選擇器在爬蟲中的核心地位在現代爬蟲開發中&#xff0c;??選擇器??是數據提取的靈魂工具。根據2023年網絡爬蟲開發者調查數據顯示&#xff1a;??92%?? 的數據提取錯誤源于選擇器編寫不當熟練使用選擇器的開發效率相比新手提升 ??300%??同時掌握CSS…

Windos服務器升級MySQL版本

Windos服務器升級MySQL版本 1.備份數據庫 windows下必須以管理員身份運行命令行工具進行備份&#xff0c;如果沒有配置MySQL的環境變量&#xff0c;需要進入MySQL Server 的bin目錄輸入指令&#xff0c; mysqldump -u root -p --all-databases > backup.sql再輸入數據庫密碼…

告別頻繁登錄!Nuxt3 + TypeScript + Vue3實戰:雙Token無感刷新方案全解析

前言 在現代 Web 應用中&#xff0c;身份認證是保障系統安全的重要環節。傳統的單 Token 認證方式存在諸多不足&#xff0c;如 Token 過期后需要用戶重新登錄&#xff0c;影響用戶體驗。本文將詳細介紹如何在 Nuxt3 TypeScript Vue3 項目中實現無感刷新 Token 機制&#xff…