SpringMVC(5)-ssm整合實現增刪改查-mybatis層

来源:https://www.cnblogs.com/XiaoMaGuai/archive/2022/05/14/16218031.html
-Advertisement-
Play Games

mybatis層編寫完畢後的項目目錄 1.右鍵SpringMVC2項目-》new-》Modual-》選擇maven項目(我的項目名為Study09_ssm),輸入模塊名,點擊Finish 2.第二部的操作就是將idea的基本運行環境搞定,包括:添加web支持,配置tomcat,配置project s ...


mybatis層編寫完畢後的項目目錄

1.右鍵SpringMVC2項目-》new-》Modual-》選擇maven項目(我的項目名為Study09_ssm),輸入模塊名,點擊Finish

2.第二部的操作就是將idea的基本運行環境搞定,包括:添加web支持,配置tomcat,配置project structure

  2.1添加web支持:右鍵項目名為Study09_ssm,選擇Add Framework Support,勾選Web Application,點擊ok

  2.2配置tomcat(註意:如果第一步沒有配置的話,tomcat裡邊不會出現這個項目的)

  2.3配置project structure,選擇idea菜單欄File->project structure->Artifact->找到自己的這個項目點擊->在WEB-INF下新建一個lib文件夾(預設是沒有的),然後點擊加號,選擇所有的依賴,點擊ok

3.新建一個資料庫命名為ssm_crud,新建一個查詢視窗,執行如下的sql代碼

USE `ssm_crud`;
DROP TABLE IF EXISTS `books`;
CREATE TABLE `books` (
  `bookID` INT(10) NOT NULL AUTO_INCREMENT COMMENT '書id',
  `bookName` VARCHAR(100) NOT NULL COMMENT '書名',
  `bookCounts` INT(11) NOT NULL COMMENT '數量',
  `detail` VARCHAR(200) NOT NULL COMMENT '描述',
  KEY `bookID` (`bookID`)
) ENGINE=INNODB DEFAULT CHARSET=utf8
INSERT  INTO `books`(`bookID`,`bookName`,`bookCounts`,`detail`)VALUES 
(1,'Java',1,'從入門到放棄'),
(2,'MySQL',10,'從刪庫到跑路'),
(3,'Linux',5,'從進門到進牢');

4.讓idea連接上MySql資料庫,具體步驟如下:找到ida右側的database選項,點擊加號-》data source-》mysql,打開data source and driver視窗,也就是第二張圖,根據步驟做完即可,完成後會出現第四張圖的樣子。

5.建立項目目錄結構,如下圖所示:Java文件夾下的四個包,web模塊不用創建

6.resources文件夾下創建下麵的三個文件

7.database.properties文件為資料庫連接串,mybatis-config.xml文件為mybatis配置,這裡只寫別名和mappers即可,其他的讓spring來做,至此mybatis層的resources文件夾下的內容搞定,applicationContext.xml是用來整合各層的配置文件的,這個最後配置。

jdbc.driver=com.mysql.jdbc.Driver
#mysql8.0+的話,要加一個時區設置&serverTimezone=Asia/Shanghai
jdbc.url=jdbc:mysql://localhost:3306/ssm_crud?useSSL=true&useUnicode=true&characterEncoding=utf8&serverTimezone=CST
jdbc.username=root
jdbc.password=123456
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

    <typeAliases>
        <package name="com.xiaoma1.pojo"/>
    </typeAliases>

    <mappers>
        <mapper class="com.xiaoma1.dao.BookMapper"></mapper>
    </mappers>
</configuration>

8.下麵來做Java文件夾下的東西,包括:實體類,dao層的mapper介面和mapper.xml配置文件,service層的介面和實現類(我們這裡主要實現對書籍的增刪改查)

   8.1編寫實體類:屬性名和資料庫欄位名一一對應,這裡的get、set方法、有參無參構造通過三個註解來實現,分別是@Data、@NoArgsConstructor、@AllArgsConstructor

package com.xiaoma1.pojo;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * Author:xiaoma
 * FileName:Books
 * Data:2022/5/3 10:21
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Books {
    private int bookID;
    private String bookName;
    private int bookCounts;
    private String detail;
}  

  8.2編寫dao層的mapper介面和mapper對應的xml文件,xml文件中編寫sql語句實現和資料庫的交互,下麵為xml配置文件代碼和介面代碼

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--綁定介面BookMapper-->
<mapper namespace="com.xiaoma1.dao.BookMapper">
    <!--//增加一本書-->
    <insert id="addBook" parameterType="Books">
        insert into books (bookName,bookCounts,detail)
        values (#{bookName},#{bookCounts},#{detail});
    </insert>

    <!--/刪除一本書-->
    <delete id="deleteBookById" parameterType="int">
        delete
        from books
        where bookID=#{id};
    </delete>

    <!--//更新一本書-->
    <update id="updateBook" parameterType="Books">
        update books
        set bookName = #{bookName},bookCounts = #{bookCounts},detail=#{detail}
        where bookID = #{bookID};
    </update>

    <!--//查詢一本書-->
    <select id="queryBookById" resultType="Books" parameterType="int">
        select *
        from books
        where bookID=#{id};
    </select>

    <!--//查詢全部的書-->
    <select id="queryAllBook" resultType="Books">
        select * from books;
    </select>

</mapper>
package com.xiaoma1.dao;

import com.xiaoma1.pojo.Books;

import java.util.List;

/**
 * Author:xiaoma
 * FileName:BookMapper
 * Data:2022/5/3 10:23
 */
public interface BookMapper {
    //增加一本書
    int addBook(Books books);

    //刪除一本書
    int deleteBookById(int id);

    //更新一本書
    int updateBook(Books books);

    //根據id查詢一本書
    Books queryBookById(int id);

    //查詢全部的書
    List<Books> queryAllBook();
}

  8.3編寫service層的介面和實現類,這裡service'層的介面和dao層的mapper介面是一樣的

package com.xiaoma1.service;

import com.xiaoma1.pojo.Books;

import java.util.List;

/**
 * Author:xiaoma
 * FileName:BookService
 * Data:2022/5/3 10:45
 */
public interface BookService {
    //增加一本書
    int addBook(Books books);

    //刪除一本書
    int deleteBookById(int id);

    //更新一本書
    int updateBook(Books books);

    //根據id查詢一本書
    Books queryBookById(int id);

    //查詢全部的書
    List<Books> queryAllBook();
}
package com.xiaoma1.service;

import com.xiaoma1.dao.BookMapper;
import com.xiaoma1.pojo.Books;

import java.util.List;

/**
 * Author:xiaoma
 * FileName:BookServiceImpl
 * Data:2022/5/3 10:45
 */

public class BookServiceImpl implements BookService{
    //業務層調用dao層,組合dao
    public BookMapper bookMapper;
    public void setBookMapper(BookMapper bookMapper) {
        this.bookMapper = bookMapper;
    }

    @Override
    public int addBook(Books books) {
        return bookMapper.addBook(books);
    }

    @Override
    public int deleteBookById(int id) {
        return bookMapper.deleteBookById(id);
    }

    @Override
    public int updateBook(Books books) {
        return bookMapper.updateBook(books);
    }

    @Override
    public Books queryBookById(int id) {
        return bookMapper.queryBookById(id);
    }

    @Override
    public List<Books> queryAllBook() {
        return bookMapper.queryAllBook();
    }
}

至此mybatis層實現完畢!!!!!!!!!

 


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

-Advertisement-
Play Games
更多相關文章
  • zset底層的數據結構為什麼使用調表而不是紅黑樹 前言 Redis中使用到的數據結構以及各個數據對象的底層數據結構在上一篇文章已經寫得非常詳細,這裡不再贅述。 https://www.cnblogs.com/ruigedada/p/16248689.html zset的底層數據結構是壓縮列表和跳錶, ...
  • 一、基礎知識 1、xml:元素、屬性和值。 2、xpath:定址語言,類似Windows目錄的查找。 語法格式: 1)"."表示自己,".."表示父親,"/"表示兒子,"//"表示後代,"name"表示按名字查找,"@name"表示按屬性查找。 2)"集合[條件]" 表示根據條件取集合的子集,條件可 ...
  • 這個問題出現在多表關聯時, 如一張商品表,其中的單位的字元串表示是在單位表中, 但這個單位的id之後進行了刪除,並且不再奏效。 如下: select * from (select pg0.id,pg0.init_size,pg0.goods_id, pg0.goods_move_size,pg0.e ...
  • 今天發現之前學的愛前端的課中JS部分函數等不全,果斷換了一個課——渡一的《Web前端開發JavaScript高薪課堂》接著學習,不過廢話有點多 1、條件語句 語法: 1、單if,條件成立,執行語句體 if (條件){ 語句體; } 2、if else,條件成立,執行if後的語句體,否則執行else的 ...
  • JS 頁面演示背景 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>ivanlee</title> <link rel="shortcut icon" href="ab_favicon.ico"> <styl ...
  • 一、概述 Scala是一門多範式的編程語言,一種類似java的編程語言 ,設計初衷是實現可伸縮的語言 、並集成面向對象編程和函數式編程的各種特性。Spark就是使用Scala編寫的。因此為了更好的學習大數據開發, 需要掌握Scala這門語言,當然Spark的興起,也帶動Scala語言的發展!官方文檔 ...
  • 實踐是唯一的真理。 #變數 ##變數的定義 變數就是可以變化的量。 JAVA變數是程式中最基礎的程式單元,其要素包括變數名,變數類型及作用域。 寫程式要註意程式的可讀性 如圖所示,可以一行寫多個對象,但是不建議。 代碼也能使用Ctrl+F搜索,方便排錯。 ##註意事項: 每個變數都有類型,類型可以是 ...
  • GO的環境配置? GOPATH GOROOT 都是幹嘛用的? 配置環境跟java對比有點奇怪 https://blog.csdn.net/weixin_40563757/article/details/115476327 語言特性 協程? 建立一個協程很簡單 加一個go關鍵字就可以 package ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...