日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

你還在用Mybatis?試試這款神器,縱享絲滑

來源: 責編: 時間:2024-03-26 17:40:05 176觀看
導讀在 Java 項目中,我們經常需要與數據庫進行交互,而 Mybatis 是一個流行的持久層框架,它可以將 Java 對象映射到 SQL 語句,從而簡化數據庫操作。不過在使用 Mybatis 做開發時,最頭痛的事情就是處理復雜業務查詢,如果將業務轉

在 Java 項目中,我們經常需要與數據庫進行交互,而 Mybatis 是一個流行的持久層框架,它可以將 Java 對象映射到 SQL 語句,從而簡化數據庫操作。YTS28資訊網——每日最新資訊28at.com

不過在使用  Mybatis 做開發時,最頭痛的事情就是處理復雜業務查詢,如果將業務轉移到service層,就會增加訪問數據庫的次數。

如果放到dao層,就要手動在xml中寫復雜的sql,用插件自動生成mapper時,會覆蓋xml中的修改,非常讓人頭疼YTS28資訊網——每日最新資訊28at.com

Fluent Mybatis是什么

Fluent Mybatis 是一個基于 Mybatis 的擴展庫,它提供了更加簡潔、易讀的 API,使得我們能夠更加高效地進行數據庫操作。YTS28資訊網——每日最新資訊28at.com

本文將介紹如何使用 Fluent Mybatis 進行基本的增刪改查操作。YTS28資訊網——每日最新資訊28at.com

使用 Fluent Mybatis 很簡單,分為以下5步:YTS28資訊網——每日最新資訊28at.com

1. 環境準備

在開始使用 Fluent Mybatis 之前,我們需要確保已經安裝了 Java 開發環境、Maven 以及 MySQL 數據庫。接下來,我們需要在項目的 pom.xml 文件中添加 Fluent Mybatis 的依賴:YTS28資訊網——每日最新資訊28at.com

<dependencies><!--引入fluent-mybatis運行依賴包,scope為compile-->        <dependency>            <groupId>com.github.atool</groupId>            <artifactId>fluent-mybatis</artifactId>            <version>1.9.3</version>        </dependency>        <!--引入fluent-mybatis-processor,scope設置為provider編譯需要,運行時不需要-->        <dependency>            <groupId>com.github.atool</groupId>            <artifactId>fluent-mybatis-processor</artifactId>            <version>1.9.3</version>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-jdbc</artifactId>            <version>2.6.2</version>        </dependency>        <dependency>            <groupId>mysql</groupId>            <artifactId>mysql-connector-java</artifactId>            <version>8.0.30</version>        </dependency></dependencies>

2. 定義表結構

CREATE TABLE `user_info` (  `id` bigint NOT NULL AUTO_INCREMENT COMMENT '自增id',  `user_name` varchar(64) DEFAULT NULL COMMENT '用戶名稱',  `user_age` int NOT NULL DEFAULT '0' COMMENT '用戶年齡',  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=101 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='用戶信息表';

3. 定義PO類

@FluentMybatis(table = "user_info") // 定義表名稱@Datapublic class UserInfoEntity extends RichEntity {    private Long id;    private String userName;    private Integer userAge;    @Override    public Class<? extends IEntity> entityClass() {        return UserInfoEntity.class;    }}

4. 編譯生成對應的mapper類

mvn clean compile

自動生成如下類:YTS28資訊網——每日最新資訊28at.com

圖片圖片YTS28資訊網——每日最新資訊28at.com

5. 配置數據源

首先,我們需要配置 Mybatis 的相關信息,如數據源、SQL 會話工廠等。這里,我們使用 Spring Boot 進行配置:YTS28資訊網——每日最新資訊28at.com

@ComponentScan(basePackages = "com.test")@MapperScan("com.test.mapper")@Configurationpublic class DataSourceConfig {    @Bean    public DataSource dataSource() {        final HikariDataSource dataSource = new HikariDataSource();        dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");        dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8");        dataSource.setUsername("root");        dataSource.setPassword("1234");        return dataSource;    }    /**     * 定義mybatis的SqlSessionFactoryBean     *     * @param dataSource     * @return     */    @Bean    public SqlSessionFactoryBean sqlSessionFactoryBean(DataSource dataSource) {        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();        bean.setDataSource(dataSource);        return bean;    }    @Bean    public MapperFactory mapperFactory() {        return new MapperFactory();    }}

如何使用 Fluent Mybatis?

下面我們使用 Fluent Mybatis 進行增刪改查的基本操作演示:YTS28資訊網——每日最新資訊28at.com

4.1 插入(Insert)

public class UserServiceTest {    @Autowired    private UserInfoMapper mapper;        @Test    public void insert() {        UserInfoEntity entity = new UserInfoEntity();        entity.setUserAge(10);        entity.setUserName("zhangsan");        mapper.insert(entity);    }}

在這個示例中,我們首先創建了一個新的 UserInfoEntity 對象,并設置了其 userName 和 userAge 屬性。然后,我們調用 UserInfoMapper.insert(entity) 方法將新用戶插入到數據庫中。YTS28資訊網——每日最新資訊28at.com

4.2 查詢(Select)

public class UserService {    @Autowired    private UserInfoMapper mapper;        @Test    public void select() {        UserInfoEntity entity = mapper.findOne(mapper.query()                .where.userName().like("zhangsan").end()                .limit(1));        System.out.println(entity);    }

在這個示例中,我們展示了如何使用 Fluent Mybatis 進行不同類型的查詢操作。我們可以根據用戶名模糊查詢用戶。YTS28資訊網——每日最新資訊28at.com

4.3 更新(Update)

public class UserService {    @Autowired    private UserInfoMapper mapper;    @Test    public void update() {        mapper.updateBy(mapper.updater()                .set.userName().is("lisi")                .set.userAge().is(20).end()                .where.id().eq(1L).end()        );    }}

在這個示例中,我們首先根據 ID 查詢到需要更新的用戶。然后,我們修改用戶的 name 和 age 屬性,并調用 UserMapper.updateBy() 方法將更新后的用戶信息保存到數據庫中。YTS28資訊網——每日最新資訊28at.com

4.4 刪除(Delete)

public class UserService {    @Autowired    private UserInfoMapper mapper;    @Test    public void delete() {        mapper.delete(mapper.query()                .where.id().eq(1L).end());    }}

在這個示例中,我們展示了如何使用 Fluent Mybatis 進行刪除操作。我們可以根據 ID 刪除用戶。YTS28資訊網——每日最新資訊28at.com

4.5 join查詢

@Test    public void joinQuery() {        JoinBuilder<FreeQuery> joinBuilder = null;        UserInfoQuery leftQuery = UserInfoQuery.query().selectAll();        UserInfoQuery rightQuery = UserInfoQuery.query().select.id("right_id").end(); // 添加別名        joinBuilder = JoinBuilder.from(leftQuery).join(rightQuery).onEq("id", "id").endJoin().build(); // join條件        FreeQuery iQuery = new FreeQuery(joinBuilder.build(), "sub").select("id", "user_name", "user_age"); // 輸出查詢字段        List<UserInfoEntity> userInfoEntities = mapper.listPoJos(UserInfoEntity.class, iQuery);        System.out.println(userInfoEntities);    }

在這個示例中,我們展示了如何使用 Fluent Mybatis 進行join查詢操作。我們將表user_info自身進行join,以id作為連接條件。YTS28資訊網——每日最新資訊28at.com

總結

通過以上示例,我們可以看到 Fluent Mybatis 提供了一套簡潔、易讀的 API,使得我們能夠更加高效地進行數據庫操作。同時,它還支持鏈式編程,讓代碼更加簡潔。如果你正在使用 Mybatis 進行數據庫操作,那么不妨嘗試一下 Fluent Mybatis,它或許會給你帶來更好的開發體驗。YTS28資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-79451-0.html你還在用Mybatis?試試這款神器,縱享絲滑

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 一個提出五年的 Node.js 模塊問題,終被解決!

下一篇: 20k級別前端是怎么使用LocalStorage的,想知道嗎?

標簽:
  • 熱門焦點
  • K60 Pro官方停產 第三方瞬間漲價

    雖然沒有官方宣布,但Redmi的一些高管也已經透露了,Redmi K60 Pro已經停產且不會補貨,這一切都是為了即將到來的K60 Ultra鋪路,屬于廠家的正常操作。但有意思的是該機在停產之后
  • 中興AX5400Pro+上手體驗:再升級 雙2.5G網口+USB 3.0這次全都有

    2021年11月的時候,中興先后發布了兩款路由器產品,中興AX5400和中興AX5400 Pro,從產品命名上就不難看出這是隸屬于同一系列的,但在外觀設計上這兩款產品可以說是完全沒一點關系
  • Automa-通過連接塊來自動化你的瀏覽器

    1、前言通過瀏覽器插件可實現自動化腳本的錄制與編寫,具有代表性的工具就是:Selenium IDE、Katalon Recorder,對于簡單的業務來說可快速實現自動化的上手工作。Selenium IDEKat
  • 虛擬鍵盤 API 的妙用

    你是否在遇到過這樣的問題:移動設備上有一個固定元素,當激活虛擬鍵盤時,該元素被隱藏在了鍵盤下方?多年來,這一直是 Web 上的默認行為,在本文中,我們將探討這個問題、為什么會發生
  • 中國家電海外掘金正當時|出海專題

    作者|吳南南編輯|胡展嘉運營|陳佳慧出品|零態LT(ID:LingTai_LT)2023年,出海市場戰況空前,中國創業者在海外紛紛摩拳擦掌,以期能夠把中國的商業模式、創業理念、戰略打法輸出海外,他們依
  • 騰訊蓋樓,字節拆墻

    來源 | 光子星球撰文 | 吳坤諺編輯 | 吳先之&ldquo;想重溫暴刷深淵、30+技能搭配暴搓到爽的游戲體驗嗎?一起上晶核,即刻暴打!&rdquo;曾憑借直播騰訊旗下代理格斗游戲《DNF》一
  • 華為Mate 60系列用上可變靈動島:正式版體驗將會更出色

    這段時間以來,關于華為新旗艦的爆料日漸密集。據此前多方爆料,今年華為將開始恢復一年雙旗艦戰略,除上半年推出的P60系列外,往年下半年的Mate系列也將
  • 朋友圈可以修改可見范圍了 蘋果用戶可率先體驗

    近日,iOS用戶迎來微信8.0.27正式版更新,除了可更換二維碼背景外,還新增了多項實用功能。在新版微信中,朋友圈終于可以修改可見范圍,簡單來說就是已發布的朋友圈
  • 聯想小新Pad Pro 12.6將要推出,搭載高通驍龍 870 處理器

    聯想小新Pad Pro 12.6將于秋季新品會上推出,官方按照慣例直接在發布會前給出了機型的所有參數。聯想小新 Pad Pro 12.6 將搭載高通驍龍 870 處理器,重量為 5
Top 主站蜘蛛池模板: 黑水县| 红安县| 广州市| 阳新县| 永和县| 尖扎县| 阿拉尔市| 温宿县| 永济市| 长丰县| 绩溪县| 彰化市| 修武县| 山东| 石门县| 罗甸县| 平遥县| 兴隆县| 高淳县| 泰安市| 宜州市| 佛冈县| 城固县| 长汀县| 桐柏县| 丰县| 盖州市| 高尔夫| 汉川市| 绥滨县| 太白县| 增城市| 贵溪市| 凤阳县| 饶阳县| 扬中市| 全州县| 墨竹工卡县| 雷山县| 临汾市| 寻乌县|